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. css3 隱藏文本2. Docker for Mac 创建的dnsmasq容器连不上/不工作的问题3. 在windows下安装docker Toolbox 启动Docker Quickstart Terminal 失败!4. dockerfile - [docker build image失败- npm install]5. javascript - js判断用户的网络能否上网?6. css - input元素的time控件无法选择7. python 字符串匹配问题8. Python Tornado批量上传图片并显示功能9. javascript - vue-router怎么不能实现跳转呢10. 请教python编码风格和异常处理问题
