JOIN ON子句中的T-SQL Case语句
发布时间:2020-12-12 07:29:58 所属栏目:MsSql教程 来源:网络整理
导读:我试图在JOIN ON子句中构建一个case / if语句. LEFT JOIN [CTSTRC] [Statuses] ON RIGHT([Statuses].[STRID],3) = [CTE].[F61] 问题是列[状态].[STRID]包含文本和数字.我将它与[CTE]进行比较.[F61]是一个整数. 有没有办法检测列[状态].[STRID]是否有字符或数
我试图在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添加到你的varcharLEFT 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] (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |