大家好我有一个问题,我的数据库有3个表
tags(id,name);
articles(id,title,smallimage,date,views);
tags_in_news(id,news_id,tag_id);
现在我想将所有article.titles附加到标签上。 我试过这个,但没多大帮助: 我的功能:
public function get($obj_id)
{
$this->load->database();
$news = $this->db->query("SELECT
t.name,
t.id,
a.title,
a.date,
a.views,
a.smallimage,
tin.id,
group_concat(a.title)
from tags_in_news tin
inner join tags t on t.id = tin.tag_id
inner join articles a on a.id = tin.news_id
and t.id = ?
group by t.id",array($obj_id));
if ($news->num_rows())
{
$news = $news->result_array();
}
else
{
$news = NULL;
}
return $news;
}
Array
(
[0] => Array
(
[name] => new tag
[id] => 57
[group_concat(a.title,a.views)] => Article1 52,Article3 51,Article3 56
)
)
答案 0 :(得分:0)
附在标签上的所有文章:
SELECT
t.name tag,GROUP_CONCAT(DISTINCT a.title) titles
FROM tags_in_news tin
INNER JOIN tags t ON t.id = tin.tag_id
INNER JOIN articles a ON a.id = tin.news_id
GROUP BY t.id;
这里要注意的一件事是GROUP_CONCAT允许的默认长度是1024个字符。
因此建议将id(如果你怀疑你的仲裁值超出限制)作为逗号分隔值,一旦得到id,你可以在之后进行点查询。