1

我正在使用 Toxi 方案在我的网站上标记项目。作为 mysql 的新手,更不用说标记了,我只是在做一个健全性检查。这是我的表初始化脚本。

CREATE TABLE IF NOT EXISTS Items (
  item_id INT UNSIGNED NOT NULL AUTO_INCREMENT ,
  item_name VARCHAR(45) NULL ,
  media_type VARCHAR(20) NULL ,
  file VARCHAR(45) NULL ,
  description VARCHAR(500) NULL ,
  PRIMARY KEY (item_id)
) ENGINE=InnoDB;

CREATE TABLE IF NOT EXISTS Tags (
 tag_id INT UNSIGNED NOT NULL AUTO_INCREMENT ,
 tag_text VARCHAR(25) NOT NULL ,
 PRIMARY KEY (tag_id) ,
 UNIQUE INDEX (tag_text)
) ENGINE=InnoDB;

CREATE TABLE IF NOT EXISTS Item2Tag (
 item_id INT UNSIGNED NOT NULL ,
 tag_id INT UNSIGNED NOT NULL  ,
 PRIMARY KEY (item_id, tag_id) ,
 INDEX (tag_id) ,
 FOREIGN KEY fk_Item (item_id) REFERENCES Items (item_id) ,
 FOREIGN KEY fk_Tag (tag_id) REFERENCES Tags (tag_id)
) ENGINE=InnoDB;

http://forge.mysql.com/wiki/TagSchema

问题 1

我的理解是否正确,“Item2Tag”表中每个“item_id”到“tag_id”都有一个条目?当我有大约 3000 个项目并且每个项目可能有大约 5 个标签时,这似乎将是一张巨大的桌子。这不是一个问题/不是一张大桌子吗?

问题2

有人可以帮助我了解拥有外键/引用的重要性吗?为什么我需要这些,它们是做什么的?

4

1 回答 1

1

问题1:是的,没错。

问题 2:据我所知,Toxi 模式并不需要它们。但是它们可以帮助您避免在参考表中出现条目而不在项目表中。与其说是需要,不如说是预防头痛的约束。IE。您删除项目编号x ,与项目编号x关联的条目也将被删除。

于 2010-11-14T23:04:54.330 回答