看错误的字面意思就清楚,一般是substring的length长度有错误。
例如:select top 10 SUBSTRING (c_dept , 1 ,CHARINDEX (',' , c_dept)-1) from ##dd_daily
要截取c_dept字段中第一个逗号前面的字符串,如果字段里面没有逗号,substring就会出错。
可以加入case判断就不会出错。
select SUBSTRING (c_dept , 1 , case
when CHARINDEX (',' , c_dept)-1 >0 then CHARINDEX (',' , c_dept)-1
when CHARINDEX (',' , c_dept)-1 <=0 then 0
end) from ##dd_daily
本文介绍如何解决 SQL 中使用 SUBSTRING 函数时遇到的常见错误,特别是当需要从字段中提取特定部分但该部分不存在时的问题。通过使用 CASE 语句可以有效地避免此类错误。
1万+

被折叠的 条评论
为什么被折叠?



