我正在尝试将一组在 SQL Server 中具有唯一列的行组合在一起。
目前所有的数据都被选择为一个标准的二维表,正在排序是 Javascript,但是,由于 JSON 非常大,对于大型列表来说非常慢。
我希望通过在服务器端转换数据集来提高前端性能,以便 DOM 渲染得更快。
我认为这可以通过 SQLgroup by
函数的某种组合来实现,并可能结合一些较openjson
新版本的 SQL Server等较新的功能。
示例表
| a | b | c | uniqueColumn |
|---|---|---|---------------|
| 1 | 2 | 3 | string1 |
| 1 | 2 | 3 | string2 |
| 4 | 5 | 6 | string3 |
示例选择
select
uniqueColumn
group by
a,
b,
c
期望输出
| uniqueSelection1 | uniqueSelection2 |
|------------------|------------------|
| string1 | string3 |
| string2 | |
a-b-c
当数据集的一部分是唯一的时,如何将每个唯一的组合分组到自己的集合中?
要使用 N 列获得上述所需结果的输出N
,唯一a,b,c
值的数量在哪里将很困难。您在应用程序端的处理速度可能比在 SQL Server 端编写和执行动态数据透视表所需的速度更快。
相反,如果您有更新的 SQL Server,使用该FOR JSON AUTO
功能可能会有所帮助,即使它与您想要的输出不完全一样:
SELECT DISTINCT (
SELECT uniqueColumn
FROM yourtable
WHERE a = t.a
AND b = t.b
AND c = t.c
FOR JSON AUTO
) AS e
FROM yourtable t;
举个例子:
CREATE TABLE test (a int, b int, c int, d varchar(30));
INSERT INTO test VALUES (1,2,3,'string1');
INSERT INTO test VALUES (1,2,3,'string2');
INSERT INTO test VALUES (4,5,6,'string3');
SELECT DISTINCT (SELECT d FROM test WHERE a=t.a AND b=t.b AND c=t.c FOR JSON AUTO) as e FROM test t;
+-----------------------------------+
| e |
+-----------------------------------+
| [{"d":"string1"},{"d":"string2"}] |
| [{"d":"string3"}] |
+-----------------------------------+
如果您想通过a,b,c
导致此输出的独特选择,您可以执行以下操作:
SELECT DISTINCT a,b,c,
(SELECT d FROM test WHERE a=t.a AND b=t.b AND c=t.c FOR JSON AUTO) as e
FROM test t
FOR JSON AUTO;
[{"a":1,"b":2,"c":3,"e":[{"d":"string1"},{"d":"string2"}]},{"a":4,"b":5,"c":6,"e":[{"d":"string3"}]}]
或者有一个表和 json 的混合结果:
SELECT DISTINCT a,b,c,
(SELECT d FROM test WHERE a=t.a AND b=t.b AND c=t.c
FOR JSON AUTO) as e
FROM test t;
+---+---+---+-----------------------------------+
| a | b | c | e |
+---+---+---+-----------------------------------+
| 1 | 2 | 3 | [{"d":"string1"},{"d":"string2"}] |
| 4 | 5 | 6 | [{"d":"string3"}] |
+---+---+---+-----------------------------------+
FOR JSON AUTO, WITHOUT_ARRAY_WRAPPER
如果您想d
从 json 数组中释放这些输出,也可以使用。您在最后一个查询上的输出将是
[{"a":1,"b":2,"c":3,"e":"{\"d\":\"string1\"},{\"d\":\"string2\"}"},{"a":4,"b":5,"c":6,"e":"{\"d\":\"string3\"}"}]
快速解释正在发生的事情:
本质上,对于d
列(您的 uniqueString)的这个子查询,我们正在做类似的事情:
SELECT a,b,c,AGGREGATE_IN_JSON(d) FROM yourtable GORUP BY a,b,c;
只是语法要求我们AGGREGATE_IN_JSON
在子查询中执行该组成的公式。
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句