c# - SQL 代码连接到一个由逗号分隔的键引用的表,并对其中的数据求和

标签 c# sql visual-studio linq tsql

我有两个这样的表:

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;

SqlFiddle up here

注意事项

信息“配对”在您的表中重复,即

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/

相关文章:

python - 限制从 SQL 查询返回无值

java - 这是一个有效的 SQLite 查询吗

visual-studio - Docker 镜像在 Windows/MVC 核心上构建的速度很慢

c# - 如何处理 Multi-Tenancy ASP MVC 站点的路径设置

c# - Monitor.TryEnter 不起作用

mysql - 根据 MySQL 中的 WHERE 子句创建具有不同值的重复更新

C# 实例复制/传递对象引用与 Java 不同吗?

asp.net - Visual Studio 可以在新的调试 session 中重新启动 IIS Express 吗?

c# - 如何在azure webjob或函数中触发多个eventhub

c# - MonoGame 3.3还有内容模板项目吗