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

nat*_*002 3 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)
Run Code Online (Sandbox Code Playgroud)

但由于某种原因,我得到一个错误说:子查询返回超过1行.我该如何解决?

Mic*_*eyn 5

该子查询为您提供每个不同的计数prop_id.您只能为其分配一个计数值prop_count.如果您打算更新prop_count与prop_ids对应的多行,则需要向更新添加一个相关子查询,该子查询将prop_idin tbl_bookings与相应的prop_idin 相关联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
Run Code Online (Sandbox Code Playgroud)

如果您真的想要更新并假设每个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
Run Code Online (Sandbox Code Playgroud)

如果要tbl_listings通过插入新的prop_ids tbl_bookings及其各自的计数来更新,您可以执行以下操作:

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
Run Code Online (Sandbox Code Playgroud)