使用数字属性名

时间:2018-05-31 21:43:00

标签: json sql-server

我正在尝试在SQL Server表中存储的某些JSON数据中返回一个值。除了我正在使用一些非常特殊的JSON数据 - 它是DICOM(医学成像标准)。在DICOM Standard for JSON中,JSON文本中的实际属性名称是数字(它们是DICOM标记号)。因此,例如,有一个包含患者ID的标签(0010,0020)。在JSON中,它看起来像这样:

{
"00100020":
    {
    "vr":"LO",
    "Value":"123456789"
    }
}

通常,我会通过执行以下查询来访问它(表名是“Instance”):

SELECT JSON_Value(JSONData,'$.00100020.Value') AS PatientID FROM Instance

但这对MSSQL无效。我收到这个错误:

Msg 13607, Level 16, State 4, Line 1
JSON path is not properly formatted. Unexpected character '0' is found at position 2.

我可以做的是编辑JSON文本看起来像这样(注意我所做的不同就是在属性名称中添加“A”前缀)...

{
"A00100020":
    {
    "vr":"LO",
    "Value":"123456789"
    }
}

执行此操作后,我可以运行此查询并成功返回结果:

SELECT JSON_Value(JSONData,'$.A00100020.Value') AS PatientID FROM Instance

唯一的区别是属性名称中包含字母字符,而不是所有数字字符。

我无法在实际操作中更改此JSON数据的格式。属性名称是数字,这就是它的方式。似乎SQL Server希望以不同的方式处理属性名称,如果它只包含数字。有没有办法强制SQL将JSON属性名称(如“00100020”)识别为实际属性名称(字符串)而不是我投入混合的数字?

提前感谢一大堆帮助!

1 个答案:

答案 0 :(得分:3)

JSON Path表达式中使用双引号。例如:

declare @doc nvarchar(max) = 
'{
"00100020":
    {
    "vr":"LO",
    "Value":"123456789"
    }
}';

SELECT JSON_Value(@doc,'$."00100020".Value') AS PatientID