标签系统的最佳模型是什么?例如,一个主题可以有N标记,标记和N可能与N 线程相关,如果我创建一个表、标记和发布一个表和这个表标记,我就有了ID of the posts,而这个标签将复制许多记录作为添加这个标记的另一个主题,这是避免这种情况的最好方法吗?

@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');发布于 2011-12-11 00:22:12
使用连接表
它至少有两列。"Posts“和"Tags”,它们之间定义主键(如果数据库允许的话,则为主键定义第三列)。

https://stackoverflow.com/questions/8460978
复制相似问题