时间:2021-05-23
本文主要讨论PostgreSQL中大小写不敏感存在的问题。
默认情况下,PostgreSQL会将列名和表名全部转换为小写状态。
图1 Person与person
如图1所示,我们创建表person,其中包含name列。然后插入一条记录。执行SELECT查询时,使用列名Name和表名Person而不是name和person,发现仍然可以正常获取刚刚插入表person中的记录。
图2 创建表Person?
此时如果我们再想创建表Person,会得到一个错误,因为此时PostgreSQL实际上把表名从Person转换成了person。由于已经存在表person,所以会报错。
通常情况下,这种大小写不敏感是很方便的,但是当我们想创建大小写敏感的表名和列名(需要使用双引号)时,会产生一些问题。
图3 创建表Person
如图3所示,我们成功创建了表Person,并插入了一条记录,此条记录和插入person中的不同以示区分。再次使用SELECT查询,并且使用表名Person和列名Name,但是返回的结果却是person中的记录。这还是因为PostgreSQL将Person转换成了person。所以想要正确查询,需要使用“Person”和“Name”(如图4所示)。
图4 获取表Person中的记录
此时查看数据库中的表(见图5),可以发现Person和person这两个表都在数据库中。如果我们使用DROP TABLE Person,删除的仍然是表person。
图5 删除操作
综上所述,当创建表或者写SQL查询语句时,建议避免使用双引号。
补充:PostgreSQL大小写不敏感排序
pg12开始支持不区分大小写,或者区分大小写的排序的collate。
语法:
CREATE COLLATION [ IF NOT EXISTS ] name ( [ LOCALE = locale, ] [ LC_COLLATE = lc_collate, ] [ LC_CTYPE = lc_ctype, ] [ PROVIDER = provider, ] [ DETERMINISTIC = boolean, ] [ VERSION = version ])CREATE COLLATION [ IF NOT EXISTS ] name FROM existing_collation其中两个关键参数:
PROVIDER:指定用于与此排序规则相关的区域服务的提供程序。可能的值是: icu、libc。 默认 是libc。但若要设置大小写不敏感,目前只支持icu。
DETERMINISTIC:设置成not deterministic表示大小写不敏感。
—正常情况的排序
我们可以看到,正常的order by会区分大小写。
bill@bill=>create table test (c1 text); CREATE TABLEbill@bill=>insert into test values ('a'),('b'),('c'),('A'),('B'),('C'); INSERT 0 6bill@bill=>select * from test order by c1; c1 ---- A B C a b c(6 rows)同样,在oracle中也是一样:
SQL> select * from test order by c1;C1--------------------------------------------------------------------------------ABCabc6 rows selected.—不区分大小写排序
可以看到我们指定collate为zh_CN时便没有区分大小写排序。
bill@bill=>select * from test order by c1 collate "zh_CN"; c1 ---- a A b B c C(6 rows)我们也可以自定义collation支持不区分大小写的排序,但是需要注意在编译数据库的时候加上 —with-icu才可以,否则会出现报错:
bill@bill=>CREATE COLLATION case_insensitive (provider = icu, locale = 'zh_Hans', deterministic = false);ERROR: ICU is not supported in this buildHINT: You need to rebuild PostgreSQL using --with-icu.正常情况:
bill@bill=> CREATE COLLATION case_insensitive (provider = icu, locale = 'zh_Hans', deterministic = false); CREATE COLLATION bill@bill=> select * from test order by c1 collate "case_insensitive"; c1 ---- a A b B c C (6 rows)目前collate不支持=操作不区分大小写,目前需要citext插件。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
当我们输入不管大小写都能查询到数据,例如:输入aaa或者aaA,AAA都能查询同样的结果,说明查询条件对大小写不敏感。解决方案一:于是怀疑Mysql的问题。做个
Javascript是无类型、解释型语言对大小写敏感html对大小写不敏感忽略空格符、制表符、换行符(关键字、变量、正则表达式除外)";"分号可选择//单行注释
Prop的大小写(camelCasevskebab-case)HTML中的特性名是大小写不敏感的,所以浏览器会把所有大写字符解释为小写字符。这意味着当你使用DO
这就意味着数据库和表名在Windows中是大小写不敏感的,而在大多数类型的Unix系统中是大小写敏感的。一个特例是MacOSX,当缺省的HFS+文件系统使用时。
mysql默认varchar类型是对大小写不敏感(不区分),如果想要mysql区分大小写需要设置排序规则:utf8_bin将字符串中的每一个字符用二进制数据存储