T-SQL使用OpenRowSet读取nvarchar

时间:2019-07-10 09:04:12

标签: sql json sql-server

我在让@jsonText包含西班牙语n之类的特殊字符时遇到问题。我相信这是因为SELECT BulkColumn FROM OPENROWSETvarchar格式返回blob。我尝试将@json_Out更改为nvarchar(MAX),但是在OPENJSON上使用@jsonText

时会导致错误
/* Dynamically read json path from i/p variable and perform the openrowset process */
DECLARE @jsonText NVARCHAR(MAX),
        @Command NVARCHAR(MAX),
        @Param_Def NVARCHAR(500),
        @FileVar NVARCHAR(MAX),
        @json_Out VARCHAR(MAX);


SET @FileVar = '\\s\storage\root\Health\To_ODS\IDC\Queue\92.json';
SET @Param_Def = N'@JSON_FILE NVARCHAR(MAX), @json_Out varchar(MAX) OUTPUT';
SET @Command = N'SELECT @json_Out = BulkColumn FROM OPENROWSET(BULK ''' + '\\s\storage\root\Health\To_ODS\IDC\Queue\92.json' + N''', SINGLE_BLOB, CODEPAGE=''65001'') ROW_SET';

EXEC sp_executesql @Command,
                   @Param_Def,
                   @JSON_FILE = @FileVar,
                   @json_Out = @jsonText OUTPUT;

SELECT * FROM openjson(@jsonText)

0 个答案:

没有答案