选择所有标记为&的线程其余的标签?

时间:2012-09-22 22:23:43

标签: php mysql sql

我试图获取标签名称为“test”的所有线程,以及所有其他标签。如果我在INNER JOIN中添加一个where子句,那么它会获得带有该标记的线程,但它不会获得该线程的剩余标记(每个标记都是一个单独的行,我使用group concat来组合它们)。我怎样才能获得剩余的标签?

我有以下SQL

SELECT `threads`.`id`,
       `threads`.`title` AS `title`,
       `threads`.`created_at` AS `created_at`,
       `threads`.`views` AS `views`,
       `threads`.`comments` AS `comments`,
       `threads`.`user_id` AS `user_id`,
       `tags`
FROM `threads`
INNER JOIN
  (SELECT threads_id,
          GROUP_CONCAT(DISTINCT `thread_tags`.`thread_tags_title`) AS tags
   FROM `thread_tags`
   WHERE `thread_tags`.`thread_tags_title` = 'test'
   GROUP BY threads_id) thread_tags ON `threads`.`id` = `thread_tags`.`threads_id`
WHERE `threads`.`status` = '1'
ORDER BY `threads`.`views` DESC, `threads`.`created_at` DESC LIMIT 25
OFFSET 0

以下方案

标签

CREATE TABLE `tags` (
  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
  `title` varchar(200) NOT NULL,
  `status` int(11) NOT NULL,
  `created_at` datetime NOT NULL,
  `updated_at` datetime NOT NULL,
  `description` varchar(255) DEFAULT NULL,
  `doctors` int(11) DEFAULT NULL,
  `threads` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=latin1;

线程标签(带有线程ID和标签ID的表)

CREATE TABLE `thread_tags` (
  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
  `threads_id` int(11) NOT NULL,
  `tag_id` int(11) NOT NULL,
  `thread_tags_title` varchar(255) NOT NULL DEFAULT '',
  `created_at` datetime NOT NULL,
  `updated_at` datetime NOT NULL,
  `description` varchar(255) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=latin1;

线程

CREATE TABLE `threads` (
  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
  `user_id` int(11) NOT NULL,
  `title` varchar(200) NOT NULL,
  `body` text NOT NULL,
  `status` int(11) NOT NULL,
  `views` int(11) NOT NULL,
  `rating` int(11) NOT NULL,
  `comments` int(11) NOT NULL,
  `created_at` datetime NOT NULL,
  `updated_at` datetime NOT NULL,
  `metadata` text,
  PRIMARY KEY (`id`),
  KEY `title` (`title`)
) ENGINE=InnoDB AUTO_INCREMENT=8 DEFAULT CHARSET=latin1;

1 个答案:

答案 0 :(得分:1)

这样的东西
SELECT threads.*, GROUP_CONCAT(tags.title)
FROM threads AS t
LEFT JOIN thread_tags AS tt ON t.id = tt.threads_id
LEFT JOIN tags AS tt ON tt.tag_id = tags.id
WHERE t.id IN (
    SELECT tt.threads_id
    FROM thread_tags AS tt
    JOIN tags ON tt.tag_id = tags.id 
             AND tags.title = "test"
)
GROUP BY t.id