gpt4 book ai didi

mysql - 实现具有多值属性的数据库的最佳方法是什么?

转载 作者:太空宇宙 更新时间:2023-11-03 10:38:59 26 4
gpt4 key购买 nike

我正在尝试实现一个具有多值属性的数据库并创建一个基于过滤器的搜索。例如,我希望我的 people_table 包含 id、姓名、地址、爱好、兴趣(爱好和兴趣是多值的)。用户将能够检查许多属性,并且 sql 将只返回具有所有属性的那些。

我进行了研究并找到了一些实现方法,但我无法决定哪一个是最好的。

  1. 第一个是有一个包含人的基本信息(id、姓名、地址)的表,另外两个用于多值属性,还有一个只包含其他表的键(我知道如何创建这个表,我还不知道如何实现搜索)。
  2. 第二个是有一个包含基本信息的表格,然后有一个表格用于每个属性。所以我将有 20 个或更多表(足球、油漆、高尔夫、音乐、远足等),它们只包含人们的 ID。然后,当用户检查爱好和事件时,我将使用 JOIN 功能获得所需的结果(我不确定其复杂性,所以我不知道如果用户这样做会有多快许多支票)。
  3. 最后一个是我在 Internet 上找不到的实现(我知道这是有原因的 :) )但在我看来,它是最容易实现的,而且在复杂性方面也是最快的。仅使用一个表,该表将像往常一样具有基本信息,并且所有属性都作为 bool 变量。因此,如果我的 table 上有 1000 个人,那么将只有 1000 个循环,而且我认为使用 AND 条件会足够快。

所以我的问题是:我可以使用第三种实现方式还是有一个我不知道的大缺点?还有你建议我使用前两种方法中的哪一种?

最佳答案

这是典型的n 到m 关系。它是这样工作的

persons table
------------
id
name
address

interests table
---------------
id
name

person_interests table
----------------------
person_id
interest_id

person_interests 包含一个人的每个兴趣的记录。要获得一个人的利益,请执行以下操作:

select i.name
from interests i
join person_interests pi on pi.interest_id = i.id
join persons p on pi.person_id = p.id
where p.name = 'peter'

您还可以为爱好 创建表格。要获得爱好,请在单独的查询中执行相同的操作。要在一个查询中同时获得两者,您可以这样做

select p.id, p.name, 
i.name as interest,
h.name as hobby
from persons p
left join person_interests pi on pi.person_id = p.id
left join interests i on pi.interest_id = i.id
left join person_hobbies ph on ph.person_id = p.id
left join hobbies h on ph.hobby_id = h.id
where p.name = 'peter'

关于mysql - 实现具有多值属性的数据库的最佳方法是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42221124/

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