我想将 aJSON_QUERY
与SELECT TOP 1
查询一起使用,以便生成的 json 以对象形式而不是表形式具有前 1 条记录?
例如,以下查询(现场演示):
CREATE TABLE Trees
(
[Id] INT,
[Type] NVARCHAR(100),
[Height] DECIMAL(2,1)
);
INSERT INTO Trees ([Id], [Type], [Height])
VALUES
(1, 'Palm', 5.5),
(2, 'Pine', 6.2),
(3, 'Apple', 2.5),
(4, 'Japanese Cedar', 0.5),
(5, 'Spanish Fir', 0.6);
SELECT
highestTree = JSON_QUERY(
(
SELECT TOP 1
Id as id,
Type as type,
Height as height
FROM Trees
WHERE Height = (SELECT Max(Height) FROM Trees)
FOR JSON PATH
)
),
lowestTree = JSON_QUERY(
(
SELECT TOP 1
Id as id,
Type as type,
Height as height
FROM Trees
WHERE Height = (SELECT MIN(Height) FROM Trees)
FOR JSON PATH
)
)
FOR JSON
PATH, WITHOUT_ARRAY_WRAPPER
;
输出:
{"highestTree":[{"id":2,"type":"Pine","height":6.2}],"lowestTree":[{"id":4,"type":"Japanese Cedar","height":0.5}]}
但我想要:
{"highestTree":{"id":2,"type":"Pine","height":6.2},"lowestTree":{"id":4,"type":"Japanese Cedar","height":0.5}}
试试这个:
结果: