【问题标题】:SQL: create new field, populate with query resultsSQL:创建新字段,填充查询结果
【发布时间】:2013-08-11 15:53:25
【问题描述】:

我有两个表:tbl_listings,列:prop_id; 和另一个表:tbl_bookings,列:prop_id、booking_date。

我想编写一个查询,计算 prop_id 出现在 tbl_bookings 中的所有时间,然后用该查询的结果填充 tbl_listings 中的一个新列。

我的查询如下:

ALTER TABLE tbl_listings
ADD COLUMN prop_count INT

UPDATE tbl_listings
    SET prop_count =
    (SELECT COUNT(*)
    FROM tbl_bookings
    GROUP BY prop_id)

但由于某种原因,我收到一条错误消息:子查询返回多于 1 行。 我该如何解决这个问题?

【问题讨论】:

  • 我认为如果您向表中添加列然后立即尝试更新它,查询将不会运行。添加列后需要使用GO

标签: sql field populate


【解决方案1】:

该子查询为您提供每个不同 prop_id 的计数。 prop_count 只能分配一个计数值。如果您打算在对应于 prop_ids 的多行中更新 prop_count,则需要将相关子查询添加到您的更新中,将 tbl_bookings 中的 prop_idtbl_listings 中的相应 prop_id 相关联。

当我更多地考虑您的问题时,我想知道您是否打算插入一个空的 tbl_listings 表而不是更新。您可以使用以下命令执行此操作:

INSERT INTO tbl_listings(prop_id,prop_count)
SELECT prop_id, COUNT(*) as prop_count
FROM tbl_bookings
GROUP BY prop_id

如果您确实打算更新并假设每个prop_id 都存在于您的tbl_listings 表中,您可以发出以下更新:

UPDATE tbl_listings
SET prop_count=(SELECT COUNT(*) 
                FROM tbl_bookings AS TB
                WHERE TB.prop_id=TL.prop_id)
FROM tbl_listings AS TL

如果您想通过插入来自tbl_bookings 的新prop_id 及其各自的计数来更新tbl_listings,您可以这样做:

INSERT INTO tbl_listings(prop_id,prop_count)
SELECT prop_id, COUNT(*) as prop_count
FROM tbl_bookings AS TB
WHERE NOT EXISTS(SELECT prop_id -- Insert only new prop_ids/counts
                 FROM tbl_listings AS TL 
                 WHERE TL.prop_id=TB.prop_id)
GROUP BY prop_id

【讨论】:

  • 谢谢迈克尔!我在编写这个 WHERE 子句时遇到了麻烦。你觉得你可以给我举个例子吗?
  • 刚刚根据您的情况用一些示例更新了我的答案,以便更具体地帮助您...
  • 很好的例子,走过不同的可能情况。很有用,谢谢!
猜你喜欢
  • 2019-09-19
  • 1970-01-01
  • 2016-03-06
  • 1970-01-01
  • 2014-05-11
  • 2020-05-27
  • 2011-10-22
  • 2013-11-03
  • 2013-07-06
相关资源
最近更新 更多