SQL:创建新字段,填充查询结果

时间:2013-08-09 16:24:42

标签: sql field populate

我有两个表: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行。 我该如何解决这个问题?

1 个答案:

答案 0 :(得分:5)

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

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

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 插入新的prop_ids及其各自的计数来更新tbl_listings,您可以这样做:

tbl_bookings