php - SQL 一条语句查询出文章和对应的文章标签
问题描述
问题解答
回答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:必须重新整合数据结构,楼上说的有道理
相关文章:
1. docker gitlab 如何git clone?2. 网页爬虫 - Python:爬虫的中文编码问题?3. javascript - 修改表单多选项时和后台同事配合的问题。4. ubuntu 远程管理KVM设置问题5. javascript - vue生成一维码?求助!!!!!急6. css - 手机页面在安卓和苹果浏览器显示不同的小小问题7. javascript - 关于Js中 this的一道题8. angular.js - angularjs如何动态改变ng-model值,在controller中获取input中输入的值并组合post发送到后台9. javascript - H5页面怎么查看console信息?10. browsersync检测的静态页面只能用index.html命名,用demo.html就不能实时同步,检测动态页面的时候,比如wamp环境下,用browsersync能打开页面,但不能实现同步
