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

)

最佳答案

附加到标签的所有文章:

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,便可以随后进行点查询。

关于mysql - 从3个表中一对多选择sql,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/23559431/

10-09 22:26