sum()函数和count()函数的区别

其实两者很好容易区分,sum,即求和,多个列相加的和; count计数,一共有多少条数据

sum()函数求累加; 对符合条件的记录的数值列求和;

count()函数求个数; 对查询中符合条件的结果(或记录)的个数

数据库中对空值的处理:sum()不计算,count()认为没有此项;

可以使用 IfNull(cloumn,0)对空值处理

sum()函数相加时,如果有一列的值为null,则结果为null

页面数据字段显示为null, 数据库中默认为null, 怎么处理显示问题?

1. 修改数据库, 默认为null改为empty String 或者 "",但这种方式对于新增的数据有效,对于已存在的数据无效, 这种在创建数据库时最好设置好

2. 后台查询时sql语句修改, 如果是varchar类型的,则 IFNULL(column,""),若是int类型,则IFNULL(colum,0),这样既可以修改显示, (推荐)

3. jsp页面做判断, 做为null处理

4. 后台写个方法,循环遍历做为null处理(不建议,数据量大时,效率低)

数据库版本问题对group by函数的影响

select 选取分组中的列+聚合函数 from 表名称 group by 分组的列

从语法格式来看,是先有分组,再确定检索的列,检索的列只能在参加分组的列中选。

所以问题中的,group by 后的 a,b,c是先确定的。select后的a,b,c才是可以变的。即

以下语句都是正确的:

select a,b,c from table_name group by a,b,c,d;

select a,b from table_name group by a,b,c;

select a,max(a) from table_name group by a,b,c;

以下语句则是错误的:

select a,b,c from table_name group by a,b;

select a,b,c from table_name group by a;

而因为MySQL的强大,它兼容了这个错误!!!

但是在DOS是不能的。所以出现了DOS下报错,而在MySQL中能够查找的情况(其实这个查找的结果是不对的)。(MySQL5.5能够兼容,5.7不能兼容)

this is incompatible with sql_mode=only_full_group_by

看一下ONLY_FULL_GROUP_BY的意思是:对于GROUP BY聚合操作,如果在SELECT中的列,没有在GROUP BY中出现,那么这个SQL是不合法的,因为列不在GROUP BY从句中,也就是说查出来的列必须在group by后面出现否则就会报错,或者这个字段出现在聚合函数里面。

例如,但是在5.5中可以正常运行,但是在5.7就不行

select id,name,age,sex from user group by sex (yes)
select id,name,age from user group by sex

解决方式:

一:在sql查询语句中不需要group by的字段上使用any_value()函数

这种对于已经开发了不少功能的项目不太合适,毕竟要把原来的sql都给修改一遍

3.1. 二:修改my.cnf(windows下是my.ini)配置文件,删掉only_full_group_by这一项

若我们项目的mysql安装在ubuntu上面,找到这个文件打开一看,里面并没有sql_mode这一配置项,想删都没得删。

当然,还有别的办法,打开mysql命令行,执行命令

1 select @@sql_mode;

这样就可以查出sql_mode的值,复制这个值,在my.cnf中添加配置项(把查询到的值删掉only_full_group_by这个选项,其他的都复制过去):

1 sql_mode=STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION;

如果 [mysqld] 这行被注释掉的话记得要打开注释。然后重重启mysql服务

注:使用命令

1 set sql_mode=STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION

这样可以修改一个会话中的配置项,在其他会话中是不生效的。

注:以上情况为操作数据库配置解决问题,如果项目已经运行一段时间后(除非刚搭好框架,刚开始运行),不建议修改数据库配置,可以修改代码

group by()的字段和要查询的字段一致,或者少于group by后的字段

mysql中sum和count的区别相关推荐

  1. MySQL中sum和count用法总结

    MySQL中sum和count用法总结 1.sum 2.count 例子:要求:查询出2门及2门以上不及格者的平均成绩. 3.MySQL 分组之后如何统计记录条数 gourp by 之后的 count ...

  2. mysql''和null,mysql中NULL和null的区别

    接触php的web开发一段时间了,在进行数据库操作的时候经常会遇到一个问题,使得同一字段在页面显示时有3种类型NULL,null以及数字,当时的解决办法是将这一字段定义为varchar类型,在插入数据 ...

  3. MySQL中In与Exists的区别

    MySQL中In与Exists的区别 1 例子 2 EXISTS和IN的介绍 2.1 exists 2.2 in 2.3 使用上的区别 3 EXISTS和IN的性能分析 4 总结 1 例子 有两个表需 ...

  4. MySQL中interactive_timeout和wait_timeout的区别

    2019独角兽企业重金招聘Python工程师标准>>> 在用mysql客户端对数据库进行操作时,打开终端窗口,如果一段时间没有操作,再次操作时,常常会报如下错误: ? 1 2 3 E ...

  5. mysql中的blob和text区别

    mysql中的blob和text区别 经过查询资料发现 除了blob 还有tinyblob longblob mediumblob 当然text还有tinytext mediumtext longte ...

  6. mysql中char与varchar的区别分析

    原文网址:http://www.jb51.net/article/23575.htm mysql中char与varchar的区别分析 作者: 字体:[增加 减小] 类型:转载 在mysql教程中cha ...

  7. mysql中where和and的区别

    本文来说下mysql中where和and的区别 文章目录 概述 内连接的时候 左外连接的时候 本文小结 概述 多表查询语法结构:table_reference {[INNER] JOIN | {LEF ...

  8. 【038】MySQL中varchar与char的区别以及varchar(50)中的50代表的涵义?

    ♣题目部分 MySQL中varchar与char的区别以及varchar(50)中的50代表的涵义? ♣答案部分 (1).varchar与char的区别区别一,定长和变长char 表示定长,长度固定, ...

  9. MySQL中distinct和distinctrow的区别

    引用官方文档的内容MySQL中distinct和distinctrow的区别 原文:The ALL and DISTINCT modifiers specify whether duplicate r ...

最新文章

  1. 最让程序员自豪的事情是什么?
  2. 英特尔用英伟达显卡,给GTA5打了个超强画质补丁
  3. 解决树莓派Virtualenv虚拟环境下GPIO问题
  4. SVN 提交出错:Attempted to lock an already-locked dir
  5. error:use of undeclared identifier
  6. [No000013F]WPF学习之X名称空间详解
  7. 我的RTOS 之二 --Threadx在skyeye上仿真測试(基于2410)
  8. spring boot 教程(二)模板依赖
  9. thinkphp5 接收layui上传的文件
  10. Windows系统C盘清理方案
  11. python基础随机数模块生成银行卡密码
  12. Xshell免密登录
  13. 2015中国(深圳)互联网金融创新峰会暨第二届云海汇梦想年会圆满成功
  14. docker insecure-registry
  15. 手机电源管理芯片一般在哪
  16. Windows 9X电脑经常出现bluescreen蓝屏怎么办?
  17. java声明一个双精度型数组_java-day4-多种语言的数组创建
  18. 盛世昊通解析新能源汽车行业排行,电动汽车也能撑起半边天
  19. 找100-200以内的质数
  20. 天池赛:宝可梦数据分析–龙系小精灵分享

热门文章

  1. pip download与pip install简介
  2. 郭敬明的一个人的城市
  3. docker中调试失败
  4. pytorch开发工具
  5. SQL Server 如何启用sa账户
  6. 计算机网络 - linux - 配置静态ip地址(NAT模式)
  7. power bi -分组累计求和
  8. Android代码中实现WAP方式联网
  9. MMDetection 快速开始,训练自定义数据集
  10. Object类的常用方法