MySQL 查询疑问?
问题描述
现在有一下三张表:
A:文章表B:评论表C:用户表
需要达到一下要求:
随机抽出三篇文章,要求输出内容中包括文章的发表用户,发表时间,文章标题,评论数量
已知:
文章标题,发表时间字段为:title,create_time,在文章表topic_list中,表中uid为public_user的id发表用户,字段为nickname,在用户表public_user中评论表为:topic_comment,其中tid为topic_list的id
需要用一个sql语句来完成,下面是我写出的,除了评论数量意外,都完成了:
select tl.id,tl.title,tl.create_time,pu.nickname from topic_list as tl left join public_user as pu on tl.uid=pu.id where tid=$tid order by rand() limit 3
想问下各位大神,怎么在这段sql的基础上,达到查询结果中有每篇文章的评论数量结果?
问题解答
回答1:不建议在SQL中rand,可以先random好id(不过你可能不知道id的范围=w=)
知道tid的情况下,可以用下面的SQL一句完成,你也可以按自己需要再修改~
SELECT `t`.`title`, `t`.`create_time`, `u`.`nickname`, COUNT(`c`.`id`)FROM `topic_list` AS `t`LEFT JOIN `public_user` AS `u` ON `t`.`uid`=`u`.`id`LEFT JOIN `topic_comment` AS `c` ON `c`.`tid`=`t`.`id`WHERE `t`.`id` IN ($tid1, $tid2, $tid3)GROUP BY `t`.`id`;回答2:
连接评论表 根据文章id分组 计算条数就行了
回答3:为什么要基于一句sql?如果一句是为了少写代码,无可厚非;如果是一句为了性能,na那么这种 sql 既难维护、难理解而且也没有所谓的性能提升,极力推荐使用主键查询。很简单,先把文章随机出来,其他的表用索引或者主键会更快:`$rand = random(1, 100) / 100;$sql = ’SELECT FROM table WHERE id >= (SELECT FLOOR( MAX(id) ’.$rand.’) FROM table ) ORDER BY id LIMIT 1;’;`
回答4:select tl.id,tl.title,tl.create_time,pu.nickname,count(tb.comment) from topic_list as t1 join public_user as pu on tl.uid=pu.id join topic_comment as tb on t1.id = tb.tidwhere tid=$tid order by rand() limit 3
相关文章:
1. python相关问题求解决,有偿2. python - 请问用cxfreeze打包的可执行程序能反编译出源码么?3. python - 用__call__ 实现装饰器功能4. html5 - H5移动端UC浏览器的,跳转下一个页面,下一个页面input输入框获取焦点后,会带出上一页的内容?5. javascript - 把字符串日期转换成一般时间格式后,发现小于10的数字不会自动添加0在前面,如下6. javascript - prismplayer播放器全屏问题7. javascript - js判断一个数组是否重复8. javascript - 在sublime中如何给.vue文件注释?9. javascript - input输入框触发change事件后,外部元素会被选中10. javascript - 这种上传图片预览怎么做?