我需要通过参数将值传递给 HashBytes 函数。当我对值进行硬编码以及使用参数时,结果会有所不同:
- 我试过玩 VarChar vs nVarChar
- 我尝试过使用 CHAR(13) 和/或 CHAR(10)
- 我已将 FileContents 的值复制到记事本和写字板中,这两者似乎都是正确的。
--Read the values from the database into a parameter
DECLARE @FileContents NVARCHAR(MAX)
DECLARE @TableContents table (TXT NVARCHAR(250))
insert into @TableContents (TXT) select TXT_0 from ZFICFIL
select * from @TableContents -- Table contents
set @FileContents = ''
SELECT @FileContents = @FileContents + char(13) + TXT FROM @TableContents
-- Drop the first CR/LF
select @FileContents = right(@FileContents, len(@FileContents)-1)
select @FileContents
DECLARE @HashThis nvarchar(MAX);
SET @HashThis = CONVERT(nvarchar(MAX),'ZAPAY190800101000001,07/02/2019 14:46:24 PM
2,300,');
SELECT HASHBYTES('SHA1', @HashThis)
SELECT HASHBYTES('SHA1', @FileContents)
表格内容给出了这个:
ZAPAY190800101000001,07/02/2019 14:46:24 PM
2,300,
@FileContents 给出了这个:
ZAPAY190800101000001,07/02/2019 14:46:24 PM
2,300,
这第一个 HashBytes,给出这个结果(硬编码):
0xB1C23ED2F33F723D7C4FF23D4415B983F08E0C6C
这第二个 HashBytes,给出这个结果(参数):
0x6A8C526D7BCD7BEA5789B53D526B8D5C77173EA2
如果我没有从表中读取,而是将其“硬编码”如下,那么它可以工作:
set @FileContents = 'ZAPAY190800101000001,07/02/2019 14:46:24 PM'
set @FileContents = @FileContents + CHAR(13) + CHAR(10) + '2,300,'
我试图将值放入文件中并从文件中读取,但这也不起作用。
set @FileContents = 'SELECT convert(varchar(MAX), *) FROM OPENROWSET(BULK ''C:\Temp\NB00002.TXT'',SINGLE_CLOB) x'
我错过了什么?