MySQL中count使用总结

一、count情况

1、count(1):可以统计表中所有数据,不统计所有的列,用1代表代码行,在统计结果中包含列字段为null的数据;

2、count(字段):只包含列名的列,统计表中出现该字段的次数,并且不统计字段为null的情况;

3、count(*):统计所有的列,相当于行数,统计结果中会包含字段值为null的列;

二、count执行效率

列名为主键,count(列名)比count(1)快;列名不为主键,count(1)会比count(列名)快;

如果表中多个列并且没有主键,则count(1)的执行效率优于count(*);

如果有主键,则select count(主键)的执行效率是最优的;如果表中只有一个字段,则select  count(*)最优。

原文地址:https://www.cnblogs.com/lz-huihui/p/11638579.html

时间: 2024-10-10 03:34:47

MySQL中count使用总结的相关文章

mysql中count,GROUP BY的用法(转载)

计算你拥有动物的总数目与“在pet表中有多少行?”是同样的问题,因为每个宠物有一个记录.COUNT(*)函数计算行数,所以计算动物数目的查询应为: mysql> SELECT COUNT(*) FROM pet;+----------+| COUNT(*) |+----------+|        9 |+----------+在前面,你检索了拥有宠物的人的名字.如果你想要知道每个主人有多少宠物,你可以使用COUNT( )函数: mysql> SELECT owner, COUNT(*) F

Mysql中count(*),DISTINCT的使用方法和效率研究

在处理一个大数据量数据库的时候突然发现mysql对于count(*)的不同处理会造成不同的结果 比如执行SELECT count(*) FROM tablename即使对于千万级别的数据mysql也能非常迅速的返回结果而对于SELECT count(*) FROM tablename WHERE.....mysql的查询时间开始攀升 仔细查阅累下手册,发现当没有WHERE语句对于整个mysql的表进行count运算的时候MyISAM类型的表中保存有总的行数,而当添加有WHERE限定语句的时候My

MySQL中Count函数的参数该传入什么样的值?

查询用户表中总记录 用户表中信息如下: 1.SELECT COUNT(*) FROM USER 结果为:3条 2.  SELECT COUNT(username) FROM USER 结果为:3条 3.  SELECT COUNT(sex) FROM USER 结果为:3条 4.  SELECT COUNT(birthday) FROM USER 结果为:0条 5.  SELECT COUNT(adress) FROM USER 结果为:2条 6.  SELECT COUNT(1) FROM U

mysql中count(),group by使用

count()统计表中或数组中记录 count(*)返回检索行的数目,且不论其值中是否包含NULL count(column_name)返回的是对列中column_name不为NULL的行的统计 例如,查询某活动的某个菜谱的用户评论数: SELECT COUNT(id) FROM uchome_comment WHERE id=530787 AND idtype='paiid' 现在想要查询每个用户评论的次数,并且按照评论次数倒序显示: SELECT COUNT(authorid) AS c,

Mysql中count(*)和limit同时使用的问题

1.带有count的sql语句只会返回一条记录 SELECT count(*) FROM `w_task` limit 0,500 结果如下图: 2.带有limit的sql语句是最后执行的 SELECT count(*) FROM `w_task` limit 1,500 以上sql语句将返回空行,因为count(*)只会使sql语句产生一条结果记录,所以后面的limit 1,500 是完全找不到的.

MongoDB和MySQL中的large skip问题、count问题

large skip 在为数据分页时,一般要skip多少记录并limit多少记录,例如在MySQL中: SELECT * FROM large_table ORDER BY `id` LIMIT 10000, 30 这个过程是很慢的,因为数据库需要从第一个记录开始扫描到第10000个记录,这个比较耗时. 在http://idning.github.io/point-large-skip.html对上面的sql代码总结了两个优化方法: 方法1: SELECT t.* FROM ( SELECT i

用count(*)还是count(列名) || Mysql中的count()与sum()区别

Mysql中的count()与sum()区别 首先创建个表说明问题 CREATE TABLE `result` ( `name` varchar(20) default NULL, `subject` varchar(20) default NULL, `score` tinyint(4) default NULL ) ENGINE=MyISAM DEFAULT CHARSET=utf8 插入一些数据, insert into result values ('张三','数学',90), ('张三

mysql中的count(primary_key)、count(1)、count(*)的区别

表结构如下: mysql> show create table user\G; *************************** 1. row *************************** Table: user Create Table: CREATE TABLE `user` ( `id` int(10) unsigned NOT NULL AUTO_INCREMENT, `name` varchar(50) NOT NULL, `pwd` varchar(50) NOT N

mysql中使用count()统计的特殊之处

如果你的需要是统计总行数时,为什么要使用count(*),而避免使用指定具体的列名?count()函数里面的参数是列名的的时候,那么会计算有值项的次数.也就是,该列没有值的项并不会进入计算范围.这样的话,你想统计的行数并不准确.更重要的是,还会增加消耗.因为,需要判断扫描所有行才知道值是否有值.如果使用count(*),它会计算总行数.不管你是否有值都会列入计算范围.另外一点:mysqlisam引擎很容易获得总行数的统计.查询速度变得更快归纳:实际编程中统计总行数是经常用到的.此时使用count