- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
ID COL1 COL2 DATE DATE2 RES
P4579841254 10 20 01/02/1900 01/04/1914 10
P4579841254 20 25 01/03/1907 02/08/1918 57
P4579841254 30 31 01/04/1914 03/12/1922 459
P4579841254 70 71 01/05/1921 05/04/1927 7895
P4579841254 70 71 01/06/1921 05/06/1927 2497
P4579841254 71 20 01/06/1928 06/08/1931 1256
P4579841254 20 75 01/07/1935 07/12/1935 325987
你好 Comm',我想通过以下条件计算 col[RES] 的总和:
COL1 >= 70 和 DATE1 >= min(DATE1)
和
COL2 <= 75 和 DATE2 <= max(DATE2)
与,
min(DATE1) 当 COL1=70 时拍摄
和
max(DATE2) 在 COL2=75 时拍摄
换句话说,我想要:“如果我们有多个 COL1=70,我们只取获得 MIN(DATE) 的那个,对于 COL2=75,我们取显示 COL2=75 的所有行的 MAX(DATE),一旦我们有了 DTmin 和 DTmax,我们取此区间内 RES 列的所有值 [DTmin;DTmax] 并求和"
对于这个 ID,结果应该是 335138(第 4 行、第 6 行和第 7 行的总和)我尝试了以下几行,但是当我必须将那些 SELECT 插入到其他上游 SELECT 中时,它对我和我的 SQL 级别(现在)变得复杂 SELECT 最终可以按 ID 进行分组:(
(SELECT "DT_MIN" FROM
(SELECT "ID",MIN("DATE1") as DT_MIN
FROM "MY_TABLE"
GROUP BY "ID","DATE1","COL1","COL2"
HAVING ("COL1"='70')
)) as "DT_MIN_vf",
(SELECT "DT_MAX" FROM
(SELECT "ID",MAX("DATE2") as DT_MAX
FROM "MY_TABLE"
GROUP BY "ID","DATE2","COL1","COL2"
HAVING ("COL2"='75')
))as "DT_MAX_vf"
需要专家的帮助!
最佳答案
这给了你预期的结果,但我不确定我是否完全理解这些要求。请拍a look at it让我知道我是否有误解。
WITH
min_d AS
(SELECT min(m2.date1) d FROM mytable m2 WHERE m2.col1 = 70),
max_d AS
(SELECT max(m2.date2) d FROM mytable m2 WHERE m2.col2 = 75)
SELECT id, SUM(res)
FROM mytable
WHERE
date1 >= (SELECT d FROM min_d)
AND (col1 <> 70 OR date1 = (SELECT d FROM min_d)) -- Handles the special case to only include the col1=70 row where date1=min_d, but unclear if it needs to be more general
AND date2 <= (SELECT d FROM max_d)
GROUP BY id
顶部的两个 CTE 获取您想要的最短和最长日期。这只是为了避免在查询中重复它们,但没有理由它们必须是 CTE。
我有 (col1 <> 70 OR ...)
的特例以确保它只包含 col1=70 的情况,其中 date1=min_d。我一点也不确定我是否理解了这个规则,但这确实会给你想要的结果。
您会注意到 COL1 >= 70
和 COL2 <= 75
不要出现在这里的任何地方,尽管你在你的问题中提到了它们。你说过 min(date1)
应该计算 col1=70(不是 >=),你说过尽管 COL1 < 70,但应该包括第 7 行,所以我不确定 COL1 >= 70
在哪里和 COL2 <= 75
是相关的。
关于SQL : How to aggregate values of one column depending on conditions applied on 2 other columns?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/73253082/
现在我已经创建了一个额外的跨度来容纳一个条件。 568 || subKey == 0" ng-repeat="links in linksWrap.links">
一些 excel IF 语句可能会变得相当长,我正在寻找一种更简单的方法来编写它们。例如,如果我要写: If($B$4+13=7,$B$4+13,FALSE) 我认为它会更容易说: If($B$4+1
我有一个包含 FromDate 、 ToDate 、 VendorName 和 GoodsName 的表单,一旦一切为真,我需要显示结果 示例: FromDate="11/20/2019"、ToDat
我经常看到使用 !!condition 而不仅仅是常规条件的代码。即: if(!!value){ doSomething(); } 对比: if(value){ doSomething
这个问题有点模棱两可,这两个在汇编代码/性能方面是否等效: public void example{ do{ //some statements; if(condition)
在我看到的使用 Any 方法的 Linq 查询示例中,大约有一半是通过将其应用于 Where() 调用的结果来实现的,另一半则直接将其应用于集合。这两种样式是否总是等效的,或者在某些情况下它们可能会返
这个问题在这里已经有了答案: What does !!(x) mean in C (esp. the Linux kernel)? (3 个答案) 关闭 9 年前。 我见过人们使用带有两个 '!'
我对部署在生产环境中的应用程序进行了线程转储,该应用程序使用 logback。我不是分析线程转储的专家,但是,我必须这样做。正在学习,网上也看了一些文章。 下面是真正的线程转储: "logback-8
在 SQL 中(特别是 Postgres): 子句 where not foo='bar' in case foo is null 评估为某种 null,导致该行不是包含在结果中。 另一方面,子句 w
是不是类似于has and condition with join和where condition after join? 例如 对于以下两个查询,它会给我相同的结果吗 1) SELECT COUNT
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
如果您调用某个函数,并且该函数在发生错误时返回 NULL(例如,想想 malloc() 或 fopen()),两个更好: FILE *fp = fopen(argv[0], "r"); if (fp
我正在使用 Azure 数据工厂 V2,我需要在父检查验证中实现两级检查。例如:如果条件一为真,那么我需要检查条件 2。并且,如果条件 2 为真,则检查条件 3。 这是一种分层检查。当我在父 IF 条
使用 Linq to Entities 有以下区别吗? db.EntityName.Where(a => a.Id == id).FirstOrDefault(); db.EntityName.Fir
我有一种情况,我已经用两种不同的方式解决了,但想知道人们对这些选项的看法,以及他们是否有其他选择...... 系统正在处理数据的“间隔”。 所有数据都分配到一个“区间” 该间隔由事实表 中的“inte
我有包含字段 Amount, Condition1, Condition2 的表格。 例子: Amount Condition1 Condition2 ---------------------
我正在尝试在 Netbeans 中制作一个简单的 MySQL、Java JDBC Web 应用程序。我希望根据当前 session 中的状态变量显示不同的内容。我尝试了以下方法: 首先,我在 .jsp
我想为 postnuke cms 设计一个主题。 并希望在模板文件中使用 css 条件。 postnuke 使用类似 smarty 的标签 .... 所以当我使用 .... 它给出了一些关于标签的错误
我想问一下asyncio.Condition .我对这个概念并不熟悉,但我从学生时代就知道并了解锁、信号量和队列。 我找不到很好的解释或典型的用例,只是 this example .我看了看来源。核心
我想知道如何在不在语句中重做相同查询两次的情况下处理 SQL 比较。这是我要找的: SELECT columnName10, IF( SELECT columnName20 FROM Othe
我是一名优秀的程序员,十分优秀!