国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

php - SQL 一條語句查詢出文章和對應的文章標簽

瀏覽:87日期:2022-06-13 14:19:54

問題描述

問題解答

回答1:

SELECT id, title, content, tagFROM article_table LEFT JOIN (SELECT article_id, group_concat(tag_name) AS tag FROM tag_table GROUP BY article_id) AS tag_data ON id = article_id;

這個是批量查詢的,單條你自己加一下article_id的限制就行了

如果你只是查詢一個article_id的話,article_id加上索引之后這里沒有任何的性能問題,不要聽下面看過幾頁書(子查詢會降低查詢效率)的人就來說什么性能問題。

回答2:

樓上的這位兄臺,你查詢的這個數據,明顯不對啊!實話告訴你吧,如果你真的想一條語句搞定,別說實現不了,就算實現了,效率也很低,其實,直接一條語句,不會出這個數據格式的數據的,別想了。建議再查一次tag標簽信息。

回答3:

建議分兩次查詢,查詢出文章信息再循環獲取標簽,這樣對性能方面會好一些。如果數據過大可以使用緩存,來存儲數據

回答4:

select t1.id,t1.title,t1.content,group_concat(t2.tag_name) tags from article t1 left join tag t2 on t1.id=t2.article_id where t1.id=1 group by t1.id

標簽表tag要根據article_id建索引,這樣的效率不會低到哪里

回答5:

支持@abul的答案,題主要求的是一條sql查出需要的結果

select t1.id,t1.title,t1.content,group_concat(t2.tag_name) tags from article t1 left join tag t2 on t1.id=t2.article_id where t1.id=1 group by t1.id;

PS:這樣的需求只針對結果集較少的情況,線上應該只是展示給用戶的一個或10個文章列表加標簽,而對于樓上小伙伴討論的數據量大了以后的問題,如果只是取出幾條文章及標簽展示給用戶,我們只需要取出這部分文章id再關聯標簽表取出標簽即可,索引建好效率不會差,再有熱門文章標簽數據我們也完全可以放到緩存中。但是如果要統計所有文章標簽的話,這就屬于生成報表了,這應該是不對前端用戶開放的,只需要后臺報表庫跑起來就好,也不用擔心效率問題影響到用戶體驗!So。。題主自己選好了

回答6:

必須重新整合數據結構,樓上說的有道理

php - SQL 一條語句查詢出文章和對應的文章標簽

相關文章:
主站蜘蛛池模板: 九九视频免费在线观看 | u影一族亚洲精品欧美激情 va欧美 | 日韩欧美亚洲综合久久99e | 成人午夜兔费观看网站 | 97在线视频免费播放 | 精品亚洲欧美高清不卡高清 | 毛片久久久 | 国产欧美视频一区二区三区 | 中国一级做a爰片久久毛片 中日韩欧美一级毛片 | 国产毛片一区 | 亚洲在线中文字幕 | 亚洲视频免费播放 | 手机在线看福利 | 国产精品成aⅴ人片在线观看 | 欧美性猛交xxx免费看人妖 | 久久精品在线视频 | 欧美在线观看高清一二三区 | 99久久这里只精品国产免费 | 亚洲天堂中文网 | 男人的天堂官网 | 欧美a级完整在线观看 | 亚洲乱码一区二区三区国产精品 | 免费一级毛片在线播放欧美 | 国产情侣真实露脸在线最新 | 欧美精品网站 | 成年人在线视频免费观看 | 久久精品网站免费观看调教 | 亚洲成人福利网站 | 日本韩经典三级在线播放 | 成人性欧美丨区二区三区 | 国产九九精品视频 | 亚洲成av人片在线观看 | 中文字幕精品一区二区精品 | 男人天堂日韩 | 亚洲黄色三级网站 | 在线欧美精品二区三区 | 黄频漫画 | 欧美成人亚洲 | 综合久久一区二区三区 | 成人合成mv福利视频网站 | 高清波多野结衣一区二区三区 |