我有两个这样的表:
InfoTable
-------------------
AVNR Substation ColumnTitle S6_name AVNRString
-------------------------------------------------------------------
1129 AHWAZ-1 T3+T4 MW 1129,1134
1130 AHWAZ-1 T3+T4 MX 1130,1135
1134 AHWAZ-1 T3+T4 MW 1129,1134
1135 AHWAZ-1 T3+T4 MX 1130,1135
8906 SHOMAL T9 MW 8906
8907 SHOMAL T9 MX 8907
和
DataTable
------------------------------------------------
Pdate Ptime AVNR Wert
------------------------------------------------
03-13-2017 01:00 1129 12.65
03-13-2017 02:00 1129 25.65
03-13-2017 03:00 1129 102.05
03-12-2017 01:00 1129 12.65
03-14-2017 01:00 1129 12.65
03-16-2017 05:00 1129 12.65
03-13-2017 01:00 1134 12.65
03-13-2017 02:00 1134 25.65
03-13-2017 03:00 1130 102.05
03-12-2017 01:00 1135 11.15
03-14-2017 01:00 1130 10.00
03-16-2017 01:00 8906 24.5
03-13-2017 01:00 8906 23.5
03-16-2017 02:00 8907 22.5
03-13-2017 01:00 8907 21.5
03-16-2017 05:00 8906 12.5
03-13-2017 02:00 8907 20.5
我想要这个结果
ResultTable
-------------------
Substation ColumnTitle S6_name Pdate pTime Sum_of_Wert
-------------------------------------------------------------------
AHWAZ-1 T3+T4 MW 03-13-2017 01:00 25.3 (sum of Wert for 1129,1134 for that date and time)
AHWAZ-1 T3+T4 MW 03-13-2017 02:00 51.3 (sum of Wert for 1129,1134 for that date and time)
AHWAZ-1 T3+T4 MW 03-13-2017 03:00 xxx
AHWAZ-1 T3+T4 MX 03-14-2017 01:00 xxx
SHOMAL T9 MW 03-13-2017 01:00 xxx
SHOMAL T9 MW 03-13-2017 02:00 xxx
……
即我想要在 AvrString
中区分每个日期和时间的 Substations
的总和值。
我是否有机会在 SQL 中执行此操作?我不是,也许在 Linq?我在 visual studio 中编程,但这很慢。我想知道是否有任何想法。
我在 visual studio 中用 sql 数据库用 c# 编程
最佳答案
这里的问题是,无论是谁设计了 InfoTable
,都没有遵守适当的 table normalization 规则。 ,并嵌入像 1129,1134
这样的字符串来指示其他行中键之间的关系,这让生活变得非常困难。
如果您使用的是现代版本的 SQL Server - 2016 或更高版本 - 您的培根保存为 STRING_SPLIT功能。
这将允许您重新规范化表格(即为 AVNRString
中的每个 AVNR
拆分行)。然后,您可以将拆分后的 AVNR
转换回 INT
以加入此操作并将其应用到分组中,即
WITH normalizeInfoTable AS
(
SELECT it.Substation, it.ColumnTitle, it.S6_name, CAST(cs.Value as INT) as AVNR
FROM InfoTable it
CROSS APPLY STRING_SPLIT (it.AVNRString, ',') cs
)
SELECT it.Substation, it.ColumnTitle, it.S6_name, dt.Pdate, dt.pTime, SUM(dt.Wert)
FROM normalizeInfoTable it
INNER JOIN DataTable dt
ON it.AVNR = dt.AVNR
GROUP BY it.Substation, it.ColumnTitle, it.S6_name, dt.Pdate, dt.pTime;
注意事项
信息“配对”在您的表中重复,即
AVNR Substation ColumnTitle S6_name AVNRString
1129 AHWAZ-1 T3+T4 MW 1129,1134
1134 AHWAZ-1 T3+T4 MW 1129,1134
产生 4 行,因为 1129 和 1134 中的每一行都将被复制两次。如果这不是所需要的,那么您可以通过在 CTE 中添加 DISTINCT
来消除重复项,即
SELECT DISTINCT it.Substation, it.ColumnTitle, it.S6_name, CAST(cs.Value as INT) as AVNR
...
另请注意,适当的规范化仍然是首选,因为可以使用外键强制执行 AVNR
关系,并且可以通过此列上的索引提高性能。应用 STRING_SPLIT
函数会降低性能。
关于c# - SQL 代码连接到一个由逗号分隔的键引用的表,并对其中的数据求和,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50597050/