【数据库】postgresql截取最后一个字符之前的所有字符,如V1.0.0.20230731110947中取V1.0.0

在PostgreSQL中,我们可以使用position函数和split_part函数来截取最后一个.之前的所有字符。这两个函数都非常有用,尤其是在处理文本数据时。

position函数

position函数用于查找一个字符串中某个子串的位置。它的语法如下:

scss 复制代码
POSITION(substring IN string)

其中,substring是要查找的子串,string是要在其中查找子串的字符串。如果找到了子串,则返回第一个匹配的位置;否则返回0。

例如,假设我们有一个名为mytable的表,其中有一列名为mycolumn的数据类型为text。我们想要找到每个记录中最后一个.之前的所有字符,可以使用以下查询:

scss 复制代码
SELECT position('.' IN mycolumn) - length(mycolumn) + 1 AS new_lengthFROM mytable;

这将返回一个新的列new_length,其中包含了每个记录中最后一个.之前的所有字符的长度。

split_part函数

split_part函数用于将一个字符串分割成多个子串。它的语法如下:

scss 复制代码
SPLIT_PART(string, delimiter, field)

其中,string是要分割的字符串,delimiter是分隔符,field是要返回的子串的位置。如果field大于字符串中的子串数,则返回空字符串。

例如,假设我们想要将mycolumn中的每个字符串按照.进行分割,并返回最后一个.之后的所有字符,可以使用以下查询:

arduino 复制代码
SELECT split_part(mycolumn, '.', -1) AS new_stringFROM mytable;

这将返回一个新的列new_string,其中包含了每个记录中最后一个.之后的所有字符。

综合运用position和split_part函数

有时候我们需要同时使用position和split_part函数来进行更复杂的文本操作。例如,假设我们想要从mycolumn中的每个字符串中提取出最后一个.之后的所有字符,但是只提取前三个字符。可以使用以下查询:

sql 复制代码
SELECT substring(mycolumn FROM position('.' IN mycolumn) - length(mycolumn) + 1 FOR 3) AS new_stringFROM mytable;

这将返回一个新的列new_string,其中包含了每个记录中最后一个.之后的前三个字符。注意,这里使用了substring函数来截取字符串的一部分。

相关推荐
CodeToGym11 小时前
【全栈进阶】Spring Boot 整合 WebSocket 实战:从实时告警到金融行情推送
java·后端·spring
Leinwin11 小时前
Moltbot 部署至 Azure Web App 完整指南:从本地到云端的安全高效跃迁
后端·python·flask
毕设源码-邱学长11 小时前
【开题答辩全过程】以 基于Springboot个人健康运动系统的设计与实现为例,包含答辩的问题和答案
java·spring boot·后端
愿你天黑有灯下雨有伞11 小时前
Spring Boot + FastExcel:打造完美的导入校验功能
java·spring boot·后端
云霄IT11 小时前
go语言post请求遭遇403反爬解决tls/ja3指纹或Cloudflare防护
开发语言·后端·golang
Dragon Wu11 小时前
OpenAPI 3.0(Swagger3/Knife4j)完整简洁注解清单
spring boot·后端·springboot
毕设源码-赖学姐11 小时前
【开题答辩全过程】以 基于Spring Boot的驾校信息管理系统的设计与实现为例,包含答辩的问题和答案
java·spring boot·后端
Chef_Chen11 小时前
数据科学每日总结--Day52--Dify使用经验
后端·dify
William_cl11 小时前
ASP.NET路由类型约束核心精讲:[HttpGet (“{id:int}“)] 整数约束吃透,附避坑指南 + 实战代码
后端·asp.net
2401_8414956412 小时前
【Web开发】基于Flask搭建简单的应用网站
后端·python·flask·视图函数·应用实例·路由装饰器·调试模式