- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有两个这样的表:
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/
我正在尝试从下拉列表中创建一个多选复选框,并通过 ; 连接所选结果。 我的代码是这样的: var myobject = { ValueA : 'Text A', ValueB : 'T
我有输入,我需要获取值并用 “|” 符号分隔。 我的输入: 输出我需要的: 00:00|00:00|00:00 我的代码是: (而且它不工作) var timesArray = $('table').
我正在尝试将超过 400 万行的列拆分为 4 个新列,问题是我不知道在哪里查看或我应该使用 Google 搜索哪个术语。 (是的,我已经在 Google 和 Stack 中搜索了一个类似的问题,但只在
我有一个很大的 csv 文件,其中充满了用“|”分隔的数字字符,例如: 432452 | 543634 4122442 | 41256512 64523 | 12416 然后我读入数据如下: fs
我有一个程序可以计算多个数字的阶乘。这些数字在 cmd 中作为参数传递: factorial.exe 3 4 5 这将分别计算 3、4 和 5 的阶乘。该程序的早期版本有一个百分比显示堆栈的完整性。我
这个问题已经有答案了: 奥 git _a (6 个回答) 已关闭 9 年前。 我有一个双数“547.123456” 我只想使用这个 double 作为“547.1”,就像“.”后面只有 1 个数字 我
我有一个程序可以计算多个数字的阶乘。这些数字在 cmd 中作为参数传递: factorial.exe 3 4 5 这将分别计算 3、4 和 5 的阶乘。该程序的早期版本有一个百分比显示堆栈的完整性。我
我有一个 ArrayList,其中包含一个 messageId、一个 -、一个用户名。 示例:E123-sam 我想划分 List 的每个元素,使得 - 之前的部分进入一个 ArrayList ,而之
我目前有一个“日期”列作为 pandas 数据框的索引,其格式为: January February .... Year2 January February ... Year3 (它来自 pdf 表格
我正在尝试对我的 .mdb 数据库进行 ODBC 查询。我正在使用 mdbtools 驱动程序。该代码是使用 Eclipse 用 C 语言编写的。唯一的问题是,当我写例如: "SELECT 'last
我需要知道如何将这两个if else 部分分开。 public static int NextBday(int Bdays, int days){ int daysleft = 0;
我想计算我的员工分开但合并在一起的出勤率 My target output 我的代码 SELECT count(employees_id) as numbers FROM attendance WH
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题吗? 通过 editing this post 添加细节并澄清问题. 关闭 7 年前。 Improve t
下面是我的代码的一小段摘录,它从 API 添加了一行。总共有很多行。 每一行包含一行数据如 TY8tr,50,34,P,SB, 数据行在数据类型上是一致的。我如何通过 ,'s 拆分数组列表中
我想获取选中的元素并用逗号分隔它们,最后一个元素用“and”分隔 它的显示输出为: 我想删除最后一个元素后面的逗号 (,) 并在它前面添加 'and',例如 Sugar, Milk and Extra
我是 JSON 的新手,但在从已解析的 JSON 对象中提取数据时遇到问题: 我有一个 getstats.php 文件,它回显 mysql 查询的 json 编码结果。以下是 php 文件返回的示例:
我有一个像这样的数字/字符串(我不确定如何将 int 与字符串相互转换) 000000122310200000223340000700012220000011411000000011011271043
标签内的文本
我想尝试一些基本的网络抓取,但遇到了一个问题,因为我习惯了简单的 td-tags,在这种情况下,我有一个网页,其中包含以下预标记和其中的所有文本,这意味着刮掉它有点棘手。 11111111 1111
出于练习目的,我正在开发 TCP 客户端/服务器系统,我想在两者之间发送特定数据。 我已经能够发送字节并让它们显示为字符串。此外,我还可以发送一个特定的字符串(“mb”)并在服务器端弹出一个 Mess
在大量的 unicode 字符中,有一些实际上表示多个字符,例如两个 'f' 字符的 U+FB00 连字 ff。有什么方法可以轻松地将这样的字符转换为多个单个字符?最好是标准 Java API 中可用
我是一名优秀的程序员,十分优秀!