- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有两个表 Product_Staging 和 Product。表格内容如下。
Product_Staging:
Account_No Product_No Cur_Revenue Prev_Revenue
12 AB 5.0 3.0
13 BC 4.0 4.0
15 DF 10.0 7.5
17 BC NULL NULL
18 AZ NULL NULL
产品:
Account_No Product_No Cur_Revenue Prev_Revenue
12 AB 1.0 3.0
13 BC 4.0 5.0
16 DF 10.0 17.5
17 CG 5.0 6.0
18 AZ NULL NULL
我需要根据以下条件更新 Product 表的 Cur_Revenue 和 Prev_Revenue 字段。
当两个表中的 Account_No 和 Product_No 匹配且收入值不同时,应在 Product 表中更新 Product_Staging 中的 Cur_Revenue 和 Prev_Revenue。
如果 Account_No 和 Product_No 的特定组合的记录存在于 Product 中,而 Product_Staging 表中不存在,则 Product 的 Cur_Revenue 和 Prev_Revenue 应设置为 NULL。
当两个表中的 Account_No 和 Product_No 匹配且收入值相同时,不应更新 Product 表。
当产品中存在特定 Account_No 和 Product_No 的记录且收入值为 NULL 时,如果 Product_Staging 中不存在 Account_No 和 Product_No 组合的记录,则不应更新产品记录。
更新后的产品:
Account_No Product_No Cur_Revenue Prev_Revenue
12 AB 5.0 3.0 (Updated from Product_Staging)
13 BC 4.0 4.0 (Updated from Product_Staging)
16 DF (Cleared)
17 CG NULL NULL (Cleared)
18 AZ NULL NULL (Not Updated)
下面的查询正在努力实现#1 和#2 的结果,但不是#3 和#4 的结果,这就是我正在努力的地方。
update p SET
p.Cur_Revenue = ps.Cur_Revenue,
p.Prev_Revenue = ps.Prev_Revenue
from Product p
LEFT JOIN Product_Staging ps on
p.Account_No= ps.Account_No AND p.Product_No = ps.Product_No
即使某个 Account_No 和 Product_No 组合的 Product 和 Product_Staging 表中的收入值相同,此查询也会更新 Product。此外,当收入值为 NULL 并且 Product_Staging 表中没有记录时,我不确定如何跳过在 Product 中更新记录。
最佳答案
您看起来非常接近,但需要将条件放入您的 SET 组件中。 LEFT-JOIN 没问题,只是你更新的基础是什么。
update p SET
p.Cur_Revenue = ps.Cur_Revenue,
p.Prev_Revenue = ps.Prev_Revenue
from
Product p
LEFT JOIN Product_Staging ps
on p.Account_No = ps.Account_No
AND p.Product_No = ps.Product_No
where
-- This is for condition #3
( NOT ps.Product_No IS NULL
AND ( p.Cur_Revenue <> ps.Cur_Revenue
OR p.Prev_Revenue <> ps.Prev_Revenue ))
OR -- This is for condition #4
( ps.Product_No IS NULL
AND p.Cur_Revenue IS NULL
AND p.Prev_Revenue IS NULL )
根据您的示例,只有 2 个条件可以更新您的 Product 表。
1 - 两个表中的匹配项和收入不同,使用分期中的值进行更新。
2 - 当暂存中没有匹配的记录时,将生产设置为NULL。
update p SET
p.Cur_Revenue = ps.Cur_Revenue,
p.Prev_Revenue = ps.Prev_Revenue
from
Product p
LEFT JOIN Product_Staging ps
on p.Account_No = ps.Account_No
AND p.Product_No = ps.Product_No
您在匹配的产品和帐户上左连接到暂存区。所以最坏的情况是你要么匹配,要么不匹配。如果您没有匹配项,则登台表中的所有值都是 NULL。如果有匹配项,您想要更新其暂存值。所以 SET 直接指向该列。根据 #1,如果匹配,则更新(你有一个值,很好)。根据#2,如果没有匹配,则设置为空(没有匹配,值为空)。所以我们甚至不需要 case/when 条件。
让我们澄清您的条件 3 和 4,以便在不必要时不更新。首先,#3,匹配且收入相同。
当两个表中的 Account_No 和 Product_No 匹配且收入值相同时,不应更新 Product 表。请注意,整个部分都包含在括号中。 NOT ps.Product_No IS NULL
表示它确实找到了与登台表的匹配项。在这种情况下,我们只想在收入中的任何一个不相同时进行更新。因此,这与 1 上的括号进行 AND 运算,或者其他收入不相同(因此 <> )。因此,如果我们有匹配的记录并且其中一个(或两个)金额不同,我们必须更新它。
( NOT ps.Product_No IS NULLAND ( p.Cur_Revenue <> ps.Cur_Revenue或者 p.Prev_Revenue <> ps.Prev_Revenue ))
当产品中存在特定 Account_No 和 Product_No 的记录且收入值为 NULL 时,如果 Product_Staging 中不存在 Account_No 和 Product_No 组合的记录,则不应更新产品记录。
在这里,第一次命中在暂存中不匹配,因此 ps.Product_No IS NULL
,而且,如果在暂存中不匹配,则两个收入字段也必须为空才能不需要更新.所以我将这两项收入与为空。如果其中一个或两个都有值,您希望根据要更新的 #2 条件将它们更改为 null。
OR ( ps.Product_No IS NULL
AND p.Cur_Revenue IS NULL
AND p.Prev_Revenue IS NULL )
关于sql - 使用 LEFT OUTER JOIN 从其他表更新表值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53637949/
IE 似乎在来自未压缩的 raphaeljs 1.4.7 的以下第 2207 行(当然,在我的代码的上下文中): gs.left != (t = left + "px") && (gs.left =
这是在操纵 $("#mydiv").position().left 还是 $("#mydiv").offset().left? $("#mydiv").animate({"left":"-100"},
这个问题在这里已经有了答案: why left+(right-left)/2 will not overflow? (7 个答案) 关闭 1 年前。 在二分搜索 while 循环中: left, r
这个问题在这里已经有了答案: why left+(right-left)/2 will not overflow? (7 个答案) 关闭 1 年前。 在二分搜索 while 循环中: left, r
我有一个 Segment 类和一个这样的段数组: private static class Segment { int number, type; Segment(in
我有一个查询,它在子选择上执行 LEFT JOIN。此查询在高负载环境中运行,并在设定的要求内执行。查询(高度简化)如下所示: SELECT table_A.pKey , table_A.uKey
我在 SO 中看到一些创建 multilanguage websites in JavaScript 的好建议包括 this article on JavaScript internationaliz
我已经使用它年了,所以是时候全面了解它了。假设这样的查询: SELECT * FROM a LEFT JOIN b ON foo... LEFT JOIN c ON bar... document
我正在尝试对搜索框执行以下 MySql 查询。我试图返回“专辑”信息(标题等),同时包含该专辑中第一张图片的缩略图。但是,我必须查找两个表才能获取图像信息。首先,photos_albums包含该相册中
我有 2 个表,我想 LEFT JOIN 并过滤 LEFT 表上的结果。这些表是: -product_table,包含列 id 和 product_name -order_table,包含列 id、p
我理解 Left Join 应该做什么吗? 我有一个问题。将其称为查询 A。它返回 19 条记录。 我有另一个查询,查询 B。它返回 1,400 条记录。 我将查询 B 作为左连接插入到查询 A 中,
我正在使用 left: auto;希望重写left: 0;但它不起作用(请参阅 jsfiddle )-我想要 居中对齐。 HTML:
为什么这不起作用?我已经分配了一堆带有 float:left 的 div,并希望设置第一个元素的位置,然后用它更新所有 sibling 的位置。 例如,我将第一个元素的 css 设置为 left:50
这应该是非常基本的 CSS,但无论我尝试什么,该死的 div 就是不会去它应该去的地方! 这是 HTML: Registe-se Nome:
我在一个 div 中嵌套了一个 div。我正在尝试显示一些文本并且有效。然而,我想要的是文本居中对齐,即它有一个 left: -50%。但它什么都不做。但是当我执行类似 left: 20px 的操作时
我有一个包含跟踪数据的表格。在其他值中,该表具有列 traffic_medium、traffic_source 和 traffic_campaign。这些列有时确实包含 (none) 或 null 作
我正在尝试 中的代码。 在 GHC 版本 6.10.4 上: data ParseState = ParseState { string :: String } deriving (Show) n
我在使用用于显示自定义配置文件字段和任何(可选)对应值的 SQL 查询时遇到问题。 这是我正在使用的 SQL 查询: SELECT pf.`id`, pf.`name`, pv.`value` FRO
我目前制作了一个包含侧边栏和内容的容器,但是当我向侧边栏添加的文本多于向容器添加的文本时,第二个侧边栏会稍微 float 到一边。这些是我正在使用的代码。 HTML: Pl
这个问题在这里已经有了答案: Difference between margin and padding? (25 个答案) 关闭 5 年前。
我是一名优秀的程序员,十分优秀!