从3个表中选择一个到多个sql

时间:2014-05-09 07:59:07

标签: mysql sql codeigniter codeigniter-2

大家好我有一个问题,我的数据库有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
    )

)

1 个答案:

答案 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,你可以在之后进行点查询。