标签系统的最佳模型

时间:2011-12-11 00:18:58

标签: mysql database tags data-modeling

标签系统的最佳模型是什么?例如,如果我创建表格,标记并发布表格,则主题可以包含N个标记,代码和N可能与N 主题相关这个表标签,我有ID of the posts和标签,会复制许多记录作为另一个主题来添加这个标签,这是避免这种情况的最佳方法吗?

enter image description here


@Quentin,问题仍然存在,它将重复表post_tags中的记录

CREATE TABLE IF NOT EXISTS `posts` (
  `pid` bigint(22) NOT NULL AUTO_INCREMENT,
  `author` varchar(25) NOT NULL,
  `content` mediumtext NOT NULL,
  PRIMARY KEY (`pid`)
) ENGINE=InnoDB  DEFAULT CHARSET=latin1 AUTO_INCREMENT=2 ;

INSERT INTO `posts` (`pid`, `author`, `content`) VALUES
(1, 'Andrey Knupp Vital', 'Hello World !');

CREATE TABLE IF NOT EXISTS `tagged` (
  `pid` bigint(22) NOT NULL,
  `tid` bigint(22) NOT NULL,
  PRIMARY KEY (`pid`,`tid`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;

INSERT INTO `tagged` (`pid`, `tid`) VALUES
(1, 1),
(1, 2);

CREATE TABLE IF NOT EXISTS `tags` (
  `tid` bigint(22) NOT NULL AUTO_INCREMENT,
  `tag` varchar(15) NOT NULL,
  PRIMARY KEY (`tid`)
) ENGINE=InnoDB  DEFAULT CHARSET=latin1 AUTO_INCREMENT=3 ;

INSERT INTO `tags` (`tid`, `tag`) VALUES
(1, 'main'),
(2, 'hello');

1 个答案:

答案 0 :(得分:7)

使用junction table

它至少有两列。 “帖子”和“标签”,主键是在它们对中定义的(如果数据库允许,则为主键的第三列)。