9

关于这个主题还有其他几个 stackoverflow 查询,但没有一个给出令人满意的答案。

我有一个表 BeerReviews,它缺少一列(review_text),另一个表 BeerReviewsWithText 缺少一个不同的列(brewery_name)。否则表格行的排序方式相同,所以我想简单地将 BeerReviews 中的 brewery_name 列附加到 BeerReviewsWithText 中。

我将 sqlite3 启动为:

sqlite3 beer_rewiews_with_text.sqlite

然后我通过以下方式附上啤酒评论表:

attach 'beer_reviews.sqlite' as BR

我通过以下方式向 BeerReviewsWithText 添加了一个空列:

alter table BeerReviewsWithText add column beer_brewername varchar;

多个 其他问题建议使用 insert 填充列,但这会将新行附加到表中,仅填充 beer_brewername 列。

insert into BeerReviewsWithText(beer_brewername) select brewery_name from BeerReviews;

相反,更新似乎填充了空值,但是当我运行以下命令(类似于另一个问题的答案)时,所有 beer_brewername 值都是相同的:

update BeerReviewsWithText set beer_brewername=(select brewery_name from BR.BeerReviews);

这似乎是一种奇怪的行为,因为我在运行时得到了预期的啤酒厂名称列表:

select brewery_name from BR.BeerReviews limit 50;

我是 sqlite 的新手,所以有人可以解释我做错了什么吗?

4

1 回答 1

12

当您使用子查询作为表达式时,如下所示:

UPDATE BeerReviewsWithText
SET beer_brewername = (SELECT brewery_name
                       FROM BR.BeerReviews)

那么只会使用子查询返回的第一条记录。

您必须编写一个返回单个记录的子查询,但外部表中的每条记录都有不同的记录。这称为相关子查询:

UPDATE BeerReviewsWithText
SET beer_brewername = (SELECT brewery_name
                       FROM BR.BeerReviews
                       WHERE ID = BeerReviewsWithText.ID)

(这假设您有一个ID列作为主键。)

于 2013-07-17T14:54:54.807 回答