标签系统的最佳模型

2 mysql database tags data-modeling

什么是标签系统的最佳模型?例如,一个主题可以有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');
Run Code Online (Sandbox Code Playgroud)

Que*_*tin 7

使用联结表

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