加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

PostgreSQL大小写排序问题

发布时间:2020-12-13 17:54:15 所属栏目:百科 来源:网络整理
导读:在PostgreSQL中创建如下表并插入如下数据 CREATE TABLE "TTT" ( ID varchar(32) PRIMARY KEY NOT NULL, NAME varchar(128) NOT NULL ); CREATE UNIQUE INDEX TTT_NAME_IDX ON "TTT"(NAME); insert into "TTT" values('1','A'); insert into "TTT" values('2'

在PostgreSQL中创建如下表并插入如下数据

CREATE TABLE "TTT" (

ID varchar(32) PRIMARY KEY NOT NULL,

NAME varchar(128) NOT NULL

);

CREATE UNIQUE INDEX TTT_NAME_IDX ON "TTT"(NAME);

insert into "TTT" values('1','A');

insert into "TTT" values('2','a');

insert into "TTT" values('3','B');

insert into "TTT" values('4','b');

此时如果执行

select * from "TTT" order by NAME;

将会得到以下结果

id | name

----------+------------

2 | a

1 | A

4 | b

3 | B

(4 rows)

这里我们期望name的排序是先按大写字母排序,然后再按照小写字母排序。

查了一下资料,可以通过如下操作来解决以上排序问题

1. 首先备份数据库配置文件和数据文件(最好导出数据),默认情况下就是/var/lib/pgsql/data目录下所有东东

2. $ sudo /etc/init.d/postgresql stop

3. $ sudo su - postgres

# initdb --lc-collate=C

4. $ sudo /etc/init.d/postgresql start

5. 再次执行以下查询

select * from "TTT" order by NAME;

结果如下:

id | name

----+------

1 | A

3 | B

2 | a

4 | b

(4 rows)

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读