mysql - 把一个表中的数据count更新到另一个表里?
伊谢尔伦
伊谢尔伦 2017-04-17 15:00:10
[MySQL讨论组]
UPDATE sites left join comments on comments.siteurl=sites.siteurl SET commentcount = count(comments.siteurl)

报错:#1111 - Invalid use of group function

sites是网站表
comments表是评论
一个网站对应多个评论
现在想把评论的数量统计出来直接更新到sites


找到个方法了:

UPDATE sites A 
INNER JOIN (SELECT *, COUNT(*) idcount FROM comments GROUP BY siteurl) as B
  ON B.siteurl = A.siteurl
SET A.commentcount = B.idcount
伊谢尔伦
伊谢尔伦

小伙看你根骨奇佳,潜力无限,来学PHP伐。

全部回复(2)
高洛峰

为何要将count写入site表 那岂不是每次comment表数据更新了你都要那count重新写入site?这样不麻烦吗?如果你只是想统计每个site的评论数。每次查询的时候像你之前那样链表就行了

大家讲道理

count是聚合函数,直接这样写是不行的。
你可以先把所有的数量查出来,然后直接在update的时候set commentcount=总数

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号