PostgreSQL 用户名大小写处理规则
PostgreSQL 用户名大小写处理规则
PostgreSQL 对用户名的处理有特定的规则,以下是详细说明:
一、基本规则
- 默认情况下:PostgreSQL 不区分用户名大小写
- 创建用户时指定的用户名会被自动转换为小写
- 连接时输入的用户名也会被转换为小写进行匹配
二、具体行为示例
1. 用户创建
-- 以下命令创建的是同一个用户(最终都是小写)
CREATE USER MyUser WITH PASSWORD '123';
CREATE USER myuser WITH PASSWORD '123';
CREATE USER MYUSER WITH PASSWORD '123';-- 验证:
SELECT usename FROM pg_user WHERE usename = 'myuser'; -- 只返回小写形式
2. 连接行为
# 以下连接方式都会成功(如果myuser存在)
psql -U myuser
psql -U MyUser
psql -U MYUSER
三、强制区分大小写的方法
如果需要区分大小写,可以使用双引号:
1. 创建区分大小写的用户
CREATE USER "MyUser" WITH PASSWORD '123'; -- 保留大小写
2. 连接时必须匹配大小写
psql -U "MyUser" # 必须带引号且大小写匹配
四、重要注意事项
-
系统视图存储:
pg_user
和pg_roles
视图中的用户名总是显示创建时的形式- 但比较时仍不区分大小写(除非创建时用了双引号)
-
密码始终区分大小写:
CREATE USER myuser WITH PASSWORD 'PassWord'; -- 连接时密码必须完全匹配大小写
-
最佳实践建议:
- 避免使用双引号创建混合大小写用户名(会增加管理复杂度)
- 保持用户名统一使用小写
- 在连接字符串中可自由使用大小写(无引号时)
五、与其他数据库对比
数据库 | 用户名大小写处理 |
---|---|
PostgreSQL | 默认不区分,双引号强制区分 |
Oracle | 默认不区分,双引号强制区分 |
MySQL | 区分大小写(取决于操作系统文件系统) |
六、问题排查
如果遇到连接问题,可检查:
-- 查看实际存储的用户名
SELECT usename FROM pg_user;-- 检查是否有双引号创建的用户
SELECT usename FROM pg_user WHERE usename <> lower(usename);