我在让@jsonText
包含西班牙语n之类的特殊字符时遇到问题。我相信这是因为SELECT BulkColumn FROM OPENROWSET
以varchar
格式返回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)