相关疑难解决方法(0)

JSON 文本格式不正确。在位置 0 处发现意外字符“N”

我是 SQL 中 JSON 的新手。我收到错误“JSON 文本格式不正确。在位置 0 处发现意外字符“N”。” 执行以下操作时 -

DECLARE @json1 NVARCHAR(4000)
set @json1 = N'{"name":[{"FirstName":"John","LastName":"Doe"}], "age":31, "city":"New York"}'
DECLARE @v NVARCHAR(4000)
set @v = CONCAT('N''',(SELECT value FROM OPENJSON(@json1, '$.name')),'''')
--select @v as 'v'
SELECT  JSON_VALUE(@v,'$.FirstName')
Run Code Online (Sandbox Code Playgroud)

“ select @v as 'v' ”给了我

N'{"FirstName":"John","LastName":"Doe"}'
Run Code Online (Sandbox Code Playgroud)

但是,在最后一个 select 语句中使用它会给我错误。

DECLARE @v1 NVARCHAR(4000)
set @v1 = N'{"FirstName":"John","LastName":"Doe"}'
SELECT  JSON_VALUE(@v1,'$.FirstName') as 'FirstName'
Run Code Online (Sandbox Code Playgroud)

也工作正常。

json sql-server-2016 sql-server-json

11
推荐指数
2
解决办法
11万
查看次数

标签 统计

json ×1

sql-server-2016 ×1

sql-server-json ×1