php - SQL 一條語(yǔ)句查詢出文章和對(duì)應(yīng)的文章標(biāo)簽
問題描述
問題解答
回答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;
這個(gè)是批量查詢的,單條你自己加一下article_id的限制就行了
如果你只是查詢一個(gè)article_id的話,article_id加上索引之后這里沒有任何的性能問題,不要聽下面看過幾頁(yè)書(子查詢會(huì)降低查詢效率)的人就來說什么性能問題。
回答2:樓上的這位兄臺(tái),你查詢的這個(gè)數(shù)據(jù),明顯不對(duì)啊!實(shí)話告訴你吧,如果你真的想一條語(yǔ)句搞定,別說實(shí)現(xiàn)不了,就算實(shí)現(xiàn)了,效率也很低,其實(shí),直接一條語(yǔ)句,不會(huì)出這個(gè)數(shù)據(jù)格式的數(shù)據(jù)的,別想了。建議再查一次tag標(biāo)簽信息。
回答3:建議分兩次查詢,查詢出文章信息再循環(huán)獲取標(biāo)簽,這樣對(duì)性能方面會(huì)好一些。如果數(shù)據(jù)過大可以使用緩存,來存儲(chǔ)數(shù)據(jù)
回答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
標(biāo)簽表tag要根據(jù)article_id建索引,這樣的效率不會(huì)低到哪里
回答5:支持@abul的答案,題主要求的是一條sql查出需要的結(jié)果
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:這樣的需求只針對(duì)結(jié)果集較少的情況,線上應(yīng)該只是展示給用戶的一個(gè)或10個(gè)文章列表加標(biāo)簽,而對(duì)于樓上小伙伴討論的數(shù)據(jù)量大了以后的問題,如果只是取出幾條文章及標(biāo)簽展示給用戶,我們只需要取出這部分文章id再關(guān)聯(lián)標(biāo)簽表取出標(biāo)簽即可,索引建好效率不會(huì)差,再有熱門文章標(biāo)簽數(shù)據(jù)我們也完全可以放到緩存中。但是如果要統(tǒng)計(jì)所有文章標(biāo)簽的話,這就屬于生成報(bào)表了,這應(yīng)該是不對(duì)前端用戶開放的,只需要后臺(tái)報(bào)表庫(kù)跑起來就好,也不用擔(dān)心效率問題影響到用戶體驗(yàn)!So。。題主自己選好了
回答6:必須重新整合數(shù)據(jù)結(jié)構(gòu),樓上說的有道理
相關(guān)文章:
1. mysql 可以從 TCP 連接但是不能從 socket 鏈接2. sql語(yǔ)句 - 如何在mysql中批量添加用戶?3. mysql 非主鍵做范圍查找實(shí)現(xiàn)原理的一點(diǎn)困惑4. java - jdbc如何返回自動(dòng)定義的bean5. 怎么php怎么通過數(shù)組顯示sql查詢結(jié)果呢,查詢結(jié)果有多條,如圖。6. mysql - 數(shù)據(jù)庫(kù)建字段,默認(rèn)值空和empty string有什么區(qū)別 1107. mysql - JAVA怎么實(shí)現(xiàn)一個(gè)DAO同時(shí)實(shí)現(xiàn)查詢兩個(gè)實(shí)體類的結(jié)果集8. mysql建表索引問題求助9. mysql - PHP定時(shí)通知、按時(shí)發(fā)布怎么做?10. 事務(wù) - mysql共享鎖lock in share mode的實(shí)際使用場(chǎng)景
