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

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

时间:2024-03-29 12:22:42浏览次数:19  
标签:子串 字符 postgresql string mycolumn V1.0 字符串 position

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

position函数

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

POSITION(substring IN string)

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

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

SELECT position('.' IN mycolumn) - length(mycolumn) + 1 AS new_length
FROM mytable;

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

split_part函数

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

SPLIT_PART(string, delimiter, field)

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

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

SELECT split_part(mycolumn, '.', -1) AS new_string
FROM mytable;

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

综合运用position和split_part函数

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

SELECT substring(mycolumn FROM position('.' IN mycolumn) - length(mycolumn) + 1 FOR 3) AS new_string
FROM mytable;

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

标签:子串,字符,postgresql,string,mycolumn,V1.0,字符串,position
From: https://www.cnblogs.com/bigleft/p/18103558

相关文章

  • 【洛谷 P8738】[蓝桥杯 2020 国 C] 天干地支 题解(字符串+数学+模运算)
    [蓝桥杯2020国C]天干地支题目描述古代中国使用天干地支来记录当前的年份。天干一共有十个,分别为:甲(jiǎ)、乙(yǐ)、丙(bǐng)、丁(dīng)、戊(wù)、己(jǐ)、庚(gēng)、辛(xīn)、壬(rén)、癸(guǐ)。地支一共有十二个,分别为:子(zǐ)、丑(chǒu)、寅(yín)、卯(mǎo)、辰(chén)、巳(sì)、午(wǔ......
  • python 根据 字符串生成唯一值
    目录Python根据字符串生成唯一值方法一:利用哈希算法生成唯一值方法二:使用UUID生成唯一值方法三:结合加密算法生成唯一值用户注册唯一标识符UUID(UniversallyUniqueIdentifier)特点:UUID版本:Python中使用UUID:应用场景:Python根据字符串生成唯一值在很多应用场景中,我......
  • 43. 字符串相乘(中)
    目录题目题解题目给定两个以字符串形式表示的非负整数num1和num2,返回num1和num2的乘积,它们的乘积也表示为字符串形式。注意:不能使用任何内置的BigInteger库或直接将输入转换为整数。示例1:输入:num1="2",num2="3"输出:"6"示例2:输入:num1="123",......
  • 文件名按数字排序,可以排序多组数字,尤其是99-333~~_222这种复杂数字组合的文件名或字符
    这是我本人编写的一个排序算法,主要就是解决复杂多组数字组合的这种文件名或者字符串的排序,排序主要规则就是从前往后对每一组数据进行排序,效果及截图如下:以下是使用方法:第一步搜索和安装我的Nuget包搜索和安装zmjtool这个包,我写的,如下图:第二步使用HMSorter的Sort方法进行......
  • 剑指offerJZ20题 表示数值的字符串 java
    描述剑指offerJZ20题表示数值的字符串请实现一个函数用来判断字符串str是否表示数值(包括科学计数法的数字,小数和整数)。科学计数法的数字(按顺序)可以分成以下几个部分:1.若干空格2.一个整数或者小数3.(可选)一个‘e’或‘E’,后面跟着一个整数(可正可负)4.若干空格......
  • PTA:滤字符
    以指针的方式,将某个字符串中出现的特定字符删去,然后输出新的字符串。输入格式:首先输入一个正整数T,表示测试数据的组数,然后是T组测试数据。每组测试数据输入一个字符串s和一个非空格字符t。其中s的长度不超过100,且只包含英文字母。输出格式:对于每组测试,将删掉t后新得......
  • 多层JSON字符串对象的差异化比较
    importcn.hutool.core.util.ObjUtil;importcn.hutool.core.util.StrUtil;importcom.fasterxml.jackson.databind.JsonNode;importcom.fasterxml.jackson.databind.ObjectMapper;importcom.fasterxml.jackson.databind.node.ObjectNode;importlombok.Data;importl......
  • C++ 字符串完全指南:学习基础知识到掌握高级应用技巧
    C++字符串字符串用于存储文本。一个字符串变量包含由双引号括起来的一组字符:示例创建一个string类型的变量并为其赋值:stringgreeting="Hello";C++字符串连接字符串连接可以使用+运算符来实现,生成一个新的字符串。示例:stringfirstName="John";stringlastN......
  • sed教程_使用sed命令向行尾添加字符(附sed元字符集)
    sed教程_使用sed命令向行尾添加字符(附sed元字符集)sed是一项Linux指令,功能同awk类似,差别在于,sed简单,对列处理的功能要差一些,awk的功能复杂,对列处理的功能比较强大。sed元字符集:^锚定行的开始,如:/^sed/匹配所有以sed开头的行。$锚定行的......
  • 【感悟《剑指offer》典型编程题的极练之路】02字符串篇!
    ​                                                                 个人主页:秋风起,再归来~                                        ......