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. 老哥们求助啊2. 求救一下,用新版的phpstudy,数据库过段时间会消失是什么情况?3. 想找个php大神仿个网站。4. pycharm运行python3.6突然出现R6034问题,请问如何处理?5. APP上传到电脑服务器,出现数据上传不完整的问题6. javascript - 使用百度文本编辑器ueditor不显示样式问题7. python执行cmd命令,怎么让他执行类似Ctrl+C效果将其结束命令?8. 微信支付 - python做微信企业付款出现CA证书错误9. mysql - thinkphp5 在MAC电脑本地正常,部署LINUX服务器之后,模型不存在10. 这是什么情况???
