您应该在两个表,问题和标签之间拆分数据,并使用questions_tags连接表将它们关联起来.
CREATE TABLE questions (
id INT UNSIGNED NOT NULL AUTO_INCREMENT,
url TEXT NOT NULL,
PRIMARY KEY (id)
);
CREATE TABLE tags (
id INT UNSIGNED NOT NULL AUTO_INCREMENT,
tag VARCHAR(255) NOT NULL,
PRIMARY KEY (id)
);
CREATE TABLE questions_tags (
question_id INT UNSIGNED NOT NULL REFERENCES questions,
tag_id INT UNSIGNED NOT NULL REFERENCES tags
);
我不确定原始表中的count列是什么,所以我跳过了它.
使用上面的表格,您可以使用联接来查找具有特定标记或问题的所有标记的所有问题.
编辑
为了获得每个标签的计数,你可以这样:
SELECT tag,
count(*) AS c
FROM tags
GROUP BY tag;
编辑
要获得所有问题的所有标记的计数,请执行以下操作:
SELECT t.tag,
q.question_id,
count(*) AS c
FROM tags AS t,
questions_tags AS qt
questions AS q
WHERE t.id = qt.tag_id
AND qt.question_id = q.id
GROUP BY t.id, q.id;
如果您只想要特定标签或问题的计数,请添加其他WHERE子句.
注意:上面的所有SQL都是未经测试的.