欢迎来到Doc100.Net免费学习资源知识分享平台!
您的位置:首页 > 程序异常 >

通改改表中字段内容,保存为原内容的后5位,不够5位的就不作处理解决思路

更新时间: 2014-05-18 08:26:43 责任编辑: Author_N8

 

通改改表中字段内容,保存为原内容的后5位,不够5位的就不作处理
通改改表中字段内容,保存为原内容的后5位,不够5位的就不作处理
例如数据:asdfghj   修改为   dfghj


--参考方法--
SQL> select substr( 'asdfdfafda ',-5,5) from dual;

SUBSTR( 'ASDFDFAFDA ',-5,5)
-------------------------
fafda
--参考方法--
通改改表中字段内容,保存为原内容的后5位,不够5位的就不作处理
用SUBSTR +case 解决

SELECT CASE WHEN LENGTH( 'fabcde ') > 5 THEN SUBSTR( 'fabcde ',-5,5)
ELSE 'fabcde ' END FROM dual
--abcde

SELECT CASE WHEN LENGTH( 'bcde ') > 5 THEN SUBSTR( 'bcde ',-5,5)
ELSE 'bcde ' END FROM dual
--bcde
--参考方法--
substr( '12345 ',-1)执行后结果为5,意思为取倒数第一位,你的substr(CPH,10,-5)不对。
select case when length(CPH)> 5 then substr(CPH,-5)
else CPH end from dual
--参考方法--
Update CCIC_LOSTcaR a set CPH=(select case when length(CPH)> 5 then substr(CPH,-5)
else CPH end from CCIC_LOSTcaR b where a.CPH=b.CPH)
上一篇:上一篇
下一篇:下一篇

 

随机推荐程序问答结果

 

 

如对文章有任何疑问请提交到问题反馈,或者您对内容不满意,请您反馈给我们DOC100.NET论坛发贴求解。
DOC100.NET资源网,机器学习分类整理更新日期::2014-05-18 08:26:43
如需转载,请注明文章出处和来源网址:http://www.doc100.net/bugs/t/889311/
本文WWW.DOC100.NET DOC100.NET版权所有。