JOIN ON子句中的T-SQL Case语句

我试图在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]

相关文章

SELECT a.*,b.dp_name,c.pa_name,fm_name=(CASE WHEN a.fm_n...
if not exists(select name from syscolumns where name=&am...
select a.*,pano=a.pa_no,b.pa_name,f.dp_name,e.fw_state_n...
要在 SQL Server 2019 中设置定时自动重启,可以使用 Window...
您收到的错误消息表明数据库 'EastRiver' 的...
首先我需要查询出需要使用SQL Server Profiler跟踪的数据库标...