我试图在JOIN ON子句中构建一个case / if语句.
LEFT JOIN [CTSTRC] [Statuses] ON RIGHT([Statuses].[STRID],3) = [CTE].[F61]
问题是列[状态].[STRID]包含文本和数字.我将它与[CTE]进行比较.[F61]是一个整数.
有没有办法检测列[状态].[STRID]是否有字符或数字,如果它是一个字符,那么设置为0?
LEFT JOIN [CTSTRC] [Statuses] ON RIGHT((CASE [Statuses].[STRID] WHEN TEXT THEN 0 ELSE CAST([Statuses].[STRID] AS INT) END),3) = [CTE].[F61]
有人能指出我正确的方向吗?
谢谢!
解决方法
你正在寻找IsNumeric,但它并不总是有用(,– 和.是数字)所以你需要使用解决方案
described by GBN,它将.0e0添加到你的varchar
LEFT JOIN [CTSTRC] [Statuses] ON (CASE WHEN ISNUMERIC(RIGHT([Statuses].[STRID],3) + '.0e0) = 1 THEN CAST(RIGHT([Statuses].[STRID],3) AS INT) ELSE 0 END) = [CTE].[F61]
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。