我正在尝试比较两种不同的列类型(不是我做的,是数据转换项目的一部分)。其中一个表格存储类似于以下内容:
0CAF3FBC-3C76-420B-B0C4-42867551E3B5
另一个将它们存储为以下内容:
{0CAF3FBC-3C76-420B-B0C4-42867551E3B5}
在此列上加入这两个表的最佳方法是什么(不幸的是,这是两者的主键)。到目前为止,我已经尝试将一个表作为一个guid(没有成功)并且还尝试构建一个类似的声明 - 但一直不确定如何处理它。
非常感谢任何帮助。
修改
如果是数据,这在语法上是否正确?
inner join report_temp.workflow_lease_proposal lp
on wif.form_guid like '%' + lp.form_guid + '%'
答案 0 :(得分:5)
在比较具有不同数据类型的值时,SQL Server退出智能。
以下脚本按原样工作,没有任何显式转换
DECLARE @TableA TABLE (VARCHARID VARCHAR(48) PRIMARY KEY)
DECLARE @TableB TABLE (GUIDID UNIQUEIDENTIFIER PRIMARY KEY)
INSERT INTO @TableA VALUES
('{0CAF3FBC-3C76-420B-B0C4-42867551E3B5}')
, ('{0CAF3FBC-3C76-420B-B0C4-42867551E3B6}')
, ( '0CAF3FBC-3C76-420B-B0C4-42867551E3B7' )
, ( '0CAF3FBC-3C76-420B-B0C4-42867551E3B8' )
INSERT INTO @TableB VALUES
('{0CAF3FBC-3C76-420B-B0C4-42867551E3B5}')
, ( '0CAF3FBC-3C76-420B-B0C4-42867551E3B6' )
, ('{0CAF3FBC-3C76-420B-B0C4-42867551E3B7}')
, ( '0CAF3FBC-3C76-420B-B0C4-42867551E3B8' )
SELECT *
FROM @TableA a
INNER JOIN @TableB b ON b.GUIDID = a.VARCHARID
结果
VARCHARID GUIDID
{0CAF3FBC-3C76-420B-B0C4-42867551E3B5} 0CAF3FBC-3C76-420B-B0C4-42867551E3B5
{0CAF3FBC-3C76-420B-B0C4-42867551E3B6} 0CAF3FBC-3C76-420B-B0C4-42867551E3B6
0CAF3FBC-3C76-420B-B0C4-42867551E3B7 0CAF3FBC-3C76-420B-B0C4-42867551E3B7
0CAF3FBC-3C76-420B-B0C4-42867551E3B8 0CAF3FBC-3C76-420B-B0C4-42867551E3B8
答案 1 :(得分:2)
inner join report_temp.workflow_lease_proposal lp
on
cast(wif.form_guid as varchar(36)) = cast(lp.form_guid as varchar(36))