gpt4 book ai didi

database - 从一个表中获取一个值(使用条件)并在一个命令中存储在另一个表中

转载 作者:搜寻专家 更新时间:2023-10-30 23:27:37 25 4
gpt4 key购买 nike

我尝试使用满足另一个表中条件的值的总和来更新表中的值。

在第一个命令中,我想获取共享文章的数量(此处为 3):

db=# select article_id,liked,shared, COUNT(article_id) FROM social WHERE article_id > 0 GROUP BY article_id,liked,shared HAVING article_id=2087 AND shared=true;
article_id | liked | shared | count
------------+-------+--------+-------
2087 | f | t | 3
(1 row)

我有另一个表,我需要将这个值 (3) 放在右列中:

db=# SELECT article_id,shared FROM articles WHERE article_id=2087;
article_id | shared
------------+--------
2087 |
(1 row)

我可以用 Python 中的两个命令来做到这一点,但我确信在一个 SQL 请求中有更好的方法来做到这一点?

编辑:

我试过这个命令:

db=# UPDATE articles SET shared=subquery.count FROM ( SELECT count(article_id) FROM social WHERE article_id=2087 AND shared=true) AS subquery WHERE article_id=2087;
UPDATE 1

db=# SELECT article_id,shared FROM articles WHERE article_id=2087;
article_id | shared
------------+--------
2087 | 3
(1 row)

我只需要设置一次 article_id 就可以了。有什么建议吗?

最佳答案

我会将计数包装在 CTE 中,并根据 CTE 的结果进行更新:

with counts as (
select article_id,liked,shared, COUNT(article_id) as article_count
FROM social
WHERE article_id > 0
GROUP BY article_id,liked,shared
HAVING article_id=2087 AND shared=true
)
update articles a
set shared = c.article_count
from counts c
where a.article_id = c.article_id

其他一些挑剔的事情......

  1. HAVING article_id=2087 and shared=true 最好移到 where 子句中。当然,这会起作用,但是 HAVING 通常保留用于聚合函数(having count (*) > 1having sum (qty) = 0。将其移动到 where 子句的好处是您可以避免抓取和聚合最终被过滤掉的数据。我不确定这一点,但它甚至可以更好地利用索引。

    <
  2. shared=true 可以简写为 shared。你可能不喜欢它的含义变得模糊不清,所以要么接受要么放弃。

  3. 第一个查询与您要更新的内容不一致...具体而言,初始查询可能会返回多个结果,因为您没有仅按 article_id 进行分组 - 因此您可能会得到大量结果相同的 article_id。您信任的这个构造将更新正确的构造。你是这个意思吗?

这三个建议的总结和一些假设:

with counts as (
select article_id, COUNT(article_id) as article_count
FROM social
WHERE article_id > 0 and article_id=2087 AND shared
GROUP BY article_id
)
update articles a
set shared = c.article_count
from counts c
where a.article_id = c.article_id

我意识到 article_id > 0article_id=2087 是多余的,但我假设后者是一个您最终会删除的测试用例,以便您可以一次更新所有记录.

关于database - 从一个表中获取一个值(使用条件)并在一个命令中存储在另一个表中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54485585/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com