gpt4 book ai didi

mysql - 在mysql中设计一个表

转载 作者:行者123 更新时间:2023-12-01 00:02:44 24 4
gpt4 key购买 nike

Mysql , php 新手在这里。请友善。

我有一个殖民地列表 - 殖民地 1、殖民地 2、...、殖民地 100。

假设 Colony5 靠近 colony4、colony9 和 colony10。Colony4 靠近 colony5、colony9、colony10 和 colony11。不同的殖民地附近有不同数量的殖民地。

如何在 mysql 中存储和获取这些数据?

目前我正在考虑一个看起来像这样的表格 ->

编号 |殖民地名称 | nearby_colony_id_1 |nearby_colony_id_2 |nearby_colony_id_3 | nearby_colony_id_4

有更好的方法吗?我希望我的问题很清楚。

最佳答案

设计表格很有趣!

如果您想将数据存储在“nereby”的地方,您可以使用图形(数据结构)来实现。如果您不关心 nearby 的细节,只关心附近有一个殖民地,您可以用另一张 table 来做。不要做你想做的事(id_2、id_3 等)这不是规范化的数据库,可能会导致异常。很多人第一次犯这个错误。

CREATE TABLE
Colonies (`id` int unsigned NOT NULL auto_increment, `name` varchar(255));
CREATE TABLE
Nearby_colonies (`a_id` int unsigned NOT NULL, `b_id` int unsigned NOT NULL);

所以您在菌落表中有您的菌落。然后,对于该殖民地附近的每个殖民地,您在 Nearby_colonies 中都有一个条目,该条目具有一对 ID(顺序无关紧要,但名称必须不同)。这将两个殖民地链接为附近的殖民地。现在,一个殖民地可以拥有任意多的 Nearby_colony 条目,而不是仅限于 id_2、id_3、id_4 等。

这也防止了异常的发生,因为关系本身是为每个群体存储的,而不仅仅是一个群体与另一个群体的关系。

如果您想更具体地存储两个殖民地之间的距离,没问题!只需将另一个字段添加到 Nearby_colonies 即可。很明显,a 菌落到 b 菌落的距离在任一方向上都是相同的;P

关于mysql - 在mysql中设计一个表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3896640/

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