Oracle去掉单列多列所有行记录前几位的字符

举例:
目的:去除表中某列的所有行记录的前几位字符。如:“QQQ玩的溜1号”,去掉前面的“QQQ”。
原始表:
在这里插入图片描述
思路:
【1】首先“QQQ”字符位于code列每一行记录的前3位,那么可以从第4位开始截取该字段,即得到想要的结果。(如QQQ玩的溜1号,去掉前面的QQQ,得到“玩的溜1号”)
【2】将想要的结果,赋值给原始的列,即覆盖掉code列即可。
方法:先查询表中截取得到的结果,然后再重新赋值给该列,操作同一张表,用别名a,b等标识,并使用id相等作为约束条件,以确保对应关系。

SQL如下:

update test a set a.code=(select substr(code,4) from test b where a.id=b.id) 

结果:
在这里插入图片描述

【延伸1】同时操作多列,去掉相同的字符串
在这里插入图片描述
去掉code列和code2列的前面字母字符串。
思路同前面的,只不过是在修改值的位置,增加多列,与之后的结果一一对应即可。
SQL如下:

update test a set (a.code, a.code2) = (select substr(code, 4), substr(code2, 4)from test b where b.id = a.id)

在这里插入图片描述
【警惕】多次执行该语句,会将字符串不断的去除,每执行一次,首三位被清掉,直到清空,需注意。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值