mysql中怎么对每一行的一个字段的值依次累

mysql中怎么对每一行的一个字段的值依次累,第1张

逐行累加,最好是在应用程序端用编程的方法解决。数据库端用SQL语句实现累加需求,数据表须要有一个自增ID列,但是系统开销会比较大。下面是示范语句供参考:

-- 利用自增id列实现累加SQL语句

select t.*,

(select sum(num) from test where id<=t.id)

as AcmNum from test t

源表数据如图

累加运行效果如图

对于count(主键id)来说, innodb引擎会遍历整张表,把每一行的id值都取出来,返回给server层,server层判断id值不为空,就按行累加

对于count(1)来说 ,innodb引擎遍历整张表,但不取值,返回给server层,server对于返回的每一行,放一个数字1进去,判断是不可能为空的,就按行累加

对于count(字段)来说,

如果这个字段定义为not null,一行行的从记录里面读出这个字段,判断不为空,则累加值

如果这个字段定义允许为null,那么执行的时候,判断到有可能为null,还要把值取出来在判断一下,不是null才累加

但是count(*)是例外

并不会把全部字段取出来,而是专门做了优化,不取值,count(*)肯定不是null,按行累加

所以这几个按照效率排序的话,count(字段)<count(主键id)<count(1)≈count(*)

所以,尽量使用count(*)

可暂时提供一个思路,若有一个表示type与name 的关系表,可以处理该关系表name字段的字符串然后与你的基础表数据进行条件查询,sum分组显示。

才疏学浅。。。一句sql貌似搞不定


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/zaji/8632082.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-19
下一篇2023-04-19

发表评论

登录后才能评论

评论列表(0条)

    保存