首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >两个表都有信息是不是更好?或者创建第三个表?

两个表都有信息是不是更好?或者创建第三个表?
EN

Stack Overflow用户
提问于 2010-02-10 10:38:19
回答 5查看 59关注 0票数 1

我有一个表GAMES和另一个PLAYERS。目前,每个“游戏”都有一个用于players_in_game的列,但我在PLAYERS表中没有对应的列。由于此列是一个数组(玩家ID #的逗号分隔列表),我认为让每个玩家的记录也包含他们所属游戏的列表可能会更好。另一方面,在两个单独的表中复制信息实际上可能需要更多的DB调用。

从长远来看,一个游戏中不太可能有超过12个玩家(通常是4-6个),但可能会有大量的游戏。

有没有好的方法来找出哪个更有效率呢?谢谢。

EN

回答 5

Stack Overflow用户

回答已采纳

发布于 2010-02-10 10:39:58

规范化通常是一件好事。表中以逗号分隔的列表表示表非常需要外键。如果您担心额外的查询,请查看JOINING

代码语言:javascript
复制
dbo.games
+----+----------+
| id |   name   |
+----+----------+
| 1  |    war   |
| 2  | invaders |
+----+----------+

dbo.players
+----+----------+---------+
| id |   name   | game_id |
+----+----------+---------+
| 1  |   john   |    1    |
| 2  |   mike   |    1    |
+----+----------+---------+

SELECT games.name, count(players.id) as total_players FROM games INNER JOIN players ON games.id = players.game_id GROUP BY games.name;

Result:
+-----------+--------------+
| name      |total_players |
+-----------+--------------+
| war       |       2      |
| invaders  |       0      |
+-----------+--------------+

附注: Go Hokies :)

票数 5
EN

Stack Overflow用户

发布于 2010-02-10 10:49:34

天啊,请不要使用CSV!!我知道当您刚接触SQL时,它很诱人,但它变得不可查询了……

您需要3个表:gamesplayersplayers_in_games。游戏和玩家都应该像id一样有一个主要的自动递增的键,然后players_in_games只需要两个字段,player_idgame_id。这被称为“多对多”关系。一个玩家可以玩多个游戏,一个游戏可以有多个玩家。

票数 2
EN

Stack Overflow用户

发布于 2010-02-10 10:42:14

正确的答案是一个名为PlayersInGames的表,它每行都有一个玩家id和一个游戏id。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2234057

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档