gpt4 book ai didi

MySQL:相交匹配一定数量特征的行

转载 作者:行者123 更新时间:2023-11-29 07:51:49 25 4
gpt4 key购买 nike

这有点难以解释,但就是这样。我有一个书籍数据库,里面有两个表。

一个用于唯一的图书关键字,即只需为每个关键字分配一个 ID:

id    |    keyword______|____________k1    |    dramak2    |    thrillerk3    |    biography

还有一个用于将图书 ID 与关键字 ID 进行匹配(即每本书的所有关键字):

book_id   |   keyword_id__________|_____________b1        |   k3b2        |   k1b2        |   k2

基本上,书“b1”有关键字“传记”,书“b2”有关键字“惊悚片”和“传记”。

我的问题是:如果我有某个图书 ID(比如“b2”),有没有办法让我在数据库中查找具有至少 2(或任何其他number) 与“b2”匹配的关键字?那么在这个例子中,其他书籍也有“k1”和“k2”作为关键字吗?这将是查找“相关书籍”的一种方式。

我欢迎任何帮助。如果您需要澄清我的问题,请告诉我!

最佳答案

是的。事实上,您只需要第二个表。

select bk.book_id, count(*)
from BookKeywords bk join
BookKeywords bkb2
on bkb2.book_id = 'b2' and
bk.keyword_id = bkb2.keyword_id
group by bk.book_id
having count(*) >= 2;

如果您想要匹配关键字的列表,可以添加group_concat(bk.keyword_id)

关于MySQL:相交匹配一定数量特征的行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26208916/

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