PostgreSQL截取某个字段中的部分内容进行排序

一.最基本的order by排序

本文使用的测试数据库信息如下:

 1.单列排序案例:查询student表中所有数据并且按照成绩从大到小排序

SELECT * FROM student order by score desc

2.多列排序案例:查询student表中所有数据并且先按照成绩从大到小排序,如果成绩相同,再按照 id 从大到小排序

两种写法均可:

SELECT * FROM "student" order by (score,id) desc

SELECT * FROM "student" order by score desc,id desc

错误写法:

SELECT * FROM "student" order by score,id desc

上述写法的意思是:先按照成绩从小到大排序,如果成绩相同,再按照id从大到小排序

二.步入正题

开发过程中遇到一个案例,例如上面student表中的学号字段(stu_number),学号前三位和后面三位都是相同的,现在需要按照stu_number的中间三位进行从大到小排序,使用了substr()函数。

SELECT substr(stu_number,4,3),* FROM "student" order by substr(stu_number,4,3) desc

效果如下:

 PostgreSQL中substr()函数的用法介绍:

1.从str内容的第2个字符开始截取,直到结束——substr(str,pos)

 

substr('HelloWord',2)

 

2.从str内容的第2个字符开始截取,截取长度为3的字符串——substr(str,pos,len)

substr('HelloWord',2,3)

substr()函数的第一个参数可以为固定的字符串内容,如上面的'HelloWord',也可以直接用数据库表中的某个字段,如上面案例中填写的stu_number字段,但是填写的字段必须为字符串类型

 

Java中substring()方法和PostgreSQL中substr()函数都是用来截取字符串的,但是用法上有些许区别:

1.Java中substring()方法的索引是从0开始的,而PostgreSQL中substr()函数的索引是从1开始的,例如:

//Java
String str = "HelloWord";
String substr = str.substring(2);

//PostgreSQL
substr('HelloWord',2)

上面的Java代码的意思是从第三个字符开始截取,直到结束,而PostgreSQL代码的意思是从第二个字符开始截取,直到结束。

 

2.参数含义不同

Java中substring(int beginIndex, int endIndex)表示从第beginIndex+1个字符开始截取,直到第endIndex个字符,例如:

String str = "HelloWord";
String substr = str.substring(2,6);

上面的Java代码的意思是从第三个字符开始截取,直到第六个字符,即截取的内容为:lloW

PostgreSQL中substr(str, pos, len)函数表示从第pos个字符开始截取,截取长度为len的字符串,例如:

substr('HelloWord',2, 6)

上面的代码的意思是从第二个字符开始截取,截取长度为6的字符串,即截取的内容为:elloWo

posted @   林林2127  阅读(1075)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
点击右上角即可分享
微信分享提示