4

我正在尝试使用“for json path”语句在复杂且嵌套的 JSON 字符串中生成大量数据,并且我正在使用多个函数来创建此 JSON 字符串的不同部分,如下所示:

declare @queue nvarchar(max)

select @queue = (
    select x.ID as layoutID
        , l.Title as layoutName
        , JSON_QUERY(queue_objects (@productID, x.ID)) as [objects]
    from Layouts x
    inner join LayoutLanguages l on l.LayoutID = x.ID
    where x.ID = @layoutid
    group by x.ID, l.Title
    for json path
)

select @queue as JSON

到目前为止,JSON 将是:

{
    "root": [{
        "layouts": [{
            "layoutID": 5
            , "layoutName": "foo"
            , "objects": []
        }]
    }]
}

然后将调用“queue_objects”函数来填写“对象”数组:

队列对象

select 0 as objectID
    , case when (select inherited_counter(@layoutID,0)) > 0 then 'false' else 'true' end as editable
    , JSON_QUERY(queue_properties (p.Table2ID)) as propertyObjects
    , JSON_QUERY('[]') as inherited
from productList p
where p.Table1ID = @productID
group by p.Table2ID 
for json path

然后 JSON 将是:

{
    "root": [{
        "layouts": [{
            "layoutID": 5
            , "layoutName": "foo"
            , "objects": [{
                "objectID": 1000
                , "editable": "true"
                , "propertyObjects": []
                , "inherited": []
            }, {
                "objectID": 2000
                , "editable": "false"
                , "propertyObjects": []
                , "inherited": []
            }]
        }]
    }]
}

还将调用“inherited_counter”和“queue_properties”函数来填充相应的键。

这只是一个示例,代码不起作用,因为我没有在这里放置函数。
但我的问题是:是函数同时相互调用,使服务器返回损坏的 JSON 字符串吗?还是服务器本身无法处理超过 2984 行的 JSON 字符串?

编辑:我的意思是 2984 行,是我在 JSON 上使用美化器,服务器不会逐行返回字符串,它返回损坏的 JSON,但在美化之后它恰好是 2984 行字符串。

4

1 回答 1

4

正如我在对 OP 的评论中所写,这可能是由于 SSMS 对结果网格中的一列中显示的字符数有限制。它对实际结果没有影响,例如结果有所有数据,只是SSMS没有全部显示。

要解决此问题,您可以增加 SSMS 检索的字符数:

SSMS 显示结果

我不建议-“一段字符串有多长”,而是将结果选择到一个nvarchar(max)变量中,然后选择PRINT那个变量。那应该给你整个文本。

希望这可以帮助!

于 2018-02-04T04:23:28.753 回答