承接国内外服务器租用托管、定制开发、网站代运营、网站seo优化托管接单、网站代更新,新老站点皆可!!咨询QQ:3787320601

浅谈PostgreSQL中大小写不敏感问题

管理员 2023-08-03 08:03:03 互联网圈 0 ℃ 0 评论 5062字 收藏

本文主要讨论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 TABLE
bill@bill=>insert into test values (‘a’),(‘b’),(‘c’),(‘A’),(‘B’),(‘C’);
INSERT 0 6
bill@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
——————————————————————————–
A
B
C
a
b
c

6 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 build
HINT: 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插件。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有毛病或未斟酌完全的地方,望不吝赐教。

文章来源:丸子建站

文章标题:浅谈PostgreSQL中大小写不敏感问题

https://www.wanzijz.com/view/68950.html

相关文章

Related articles

X

截屏,微信识别二维码

微信号:weimawl

(点击微信号复制,添加好友)

打开微信