mysql count count id_mysql 为什么count(*)快于count(id)

其实,挺正常的,count的用法大概有两个,不过一般大家不太注意:

统计某个列( 俗称字段 )有多少个有效值,也就是值不是null的有多少个。

统计记录有多少行,我背诵过的规则是这样的:当count()括弧的表达式被认为不可能为空时,就会自动忽略所有列,直接统计结果记录一共多少行。曾经以为,*的时候,会自动扩展展开所有的列,其实不是。可能是受select(星号)影响。

当不指定条件的时候,count是很快的,指定条件速度会下降。

mysql在设计上,count(星号)性能是很快的,即便是加上where,它就是要比count(col)快,因为count(col)要判断每行是不是NULL,而count( 星号 )也并不是想象中那样扩展所有列,它会直接忽略列而直接统计结果集行数,只要有行就纳入统计,具体这行每列的值是什么对它来说根本不重要,跟select(*)是不同的。

结论就是,如果你要统计记录条数一共多少条,一定要用count(*),而不是count(col),它的性能会更好。当引擎发现你的col不可能为null的时候,它会将col转换成星号,如果楼主用的id时主键,那么其实会被转化成星号,这转化也是耗费性能的。

补充一下:myisam引擎状况下,如果不指定where条件,那么myisam是很迅速,因为不指定条件会直接读取存储引擎存储的一个特殊字段,值是总行数,但是一旦指定where条件,迅速的神话也就没了,沦落和其他引擎差不多了。

易企达10年行业沉淀!专业小程序、公众号H5、APP定制开发

本文原地址:https://www.eqiday.com/66.html

郑重声明内容版权声明:除非注明,否则皆为本站原创文章。如有侵权联系进行删除!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/551035.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

如何修改操作系统运行服务器,如何设置Bios 最常见bios设置与修改详细图解教程...

平时我们在使用计算机的时候一般很少会接触到BIOS,很多人都是在安装操作系统时才接触到的,因为在使用光盘安装系统时需将计算机的BIOS设置为从光驱启动,在重装系统、设置硬盘模式以及一些特殊情况都需要进入bios里面,进行相关设置…

mysql 回滚失败_Mysql非事务表回滚失败的现象

执行ROLLBACK(回滚)时,如果收到下述消息,表示事务中使用的1个或多个表不支持事务: 警告:某些更改的非事务性表不能被回滚。 这些非事务性表不受ROLLBACK语句的影响。 如果在事务中意外地混合了事务性表和非事务性表,导…

在线服务器和客户端聊天,实验三、客户端和服务器能实现简单的聊天功能

《实验三、客户端和服务器能实现简单的聊天功能》由会员分享,可在线阅读,更多相关《实验三、客户端和服务器能实现简单的聊天功能(6页珍藏版)》请在人人文库网上搜索。1、实验三、客户端和服务器能实现简单的聊天功能1、实验目的:熟悉基于流式…

mysql连表查询on条件_mysql 外连接的时候,条件在on后面和条件在where后面的区别...

最近使用mysql的时候碰到一个问题:当一个表外联另一个表的时候,将一些查询条件放在on后面和放在where后面不太一样:学生分数表stuscore:当查询语句如下(查询语句1):SELECT a.name,a.subject,a.score,a.stuid ,b.name,b…

应运ajax的几种语言,Ajax指的是什么

Ajax指的是什么发布时间:2020-08-05 14:18:52来源:亿速云阅读:103作者:小新这篇文章将为大家详细讲解有关Ajax指的是什么,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可…

oracle 数据导入 mysql_oracle数据库导出和oracle导入数据的二种方法(oracle导入导出数据)...

这篇文章主要介绍了oracle导入导出数据的二种方法,利用PL/SQL Developer工具导出和利用cmd的操作命令导出的出方法,大家参考使用吧方法一:利用PL/SQL Developer工具导出:菜单栏---->Tools---->Export Tables,如下…

iphone文件怎么上传到服务器,iPhone编程中文件上传到HTTP服务器

宝慕林4294392下面的代码使用HTTPPOST将NSData发布到Web服务器。您还需要一些PHP方面的知识。NSString *urlString "http://yourserver.com/upload.php";NSString *filename "filename";request [[[NSMutableURLRequest alloc] init] autorelease];[requ…

tomcat 启动项目 页面文字乱码_项目通过tomcat部署到服务器,请求数据页面中文乱码问题...

问题描述:1、将项目部署到服务器之后从页面接收的中文乱码2、数据库中原有的数据都能正常显示产生原因:没有对Tomcat服务器和mysql进行配置更改解决流程:一、 修改Tomcat配置更改两个文件的配置1.server.xml(添加红色部分)URIEncoding"U…

小米手机文件 ftp服务器,小米手机与电脑FTP连接(不用每一次都输入ftp地址)...

用过小米miui的用户都知道,miui的“文件管理”里边有一个非常好用的功能-远程管理,如果手机与电脑都在同一个wifi网络下,即同一个局域网内,不用数据线直接就可以连接。打开手机的文件管理—远程管理—启动服务,将生成一…

第五人格服务器维修中怎么进,第五人格进不去怎么办 游戏进不去解决方法详解[多图]...

第五人格开启测试已经有一段时间,许多玩家都会遇到各种问题,其中游戏进不去是让玩家最头痛的,今天安族小编来给大家介绍一下游戏进不去解决方法详解。第五人格进不去解决方法大家在玩的时候,肯定都会遇到卡顿、进不去或者是不能玩…

mysql数据库查询语句过程_mysql(一) SQL查询语句执行过程

mysql基础架构 示意图首先 mysql 大概分为 server层 和 存储引擎层 两个部分, 引擎的架构模式是插件形式的,mysql支持多种引擎如 InnoDB、MyISAM、Memory 等,其中 Innodb是应用最广泛的,mysql5.5.5版本后,将Innodb设为…

Ajax解析laravelJSON,3分钟短文:Laravel请求体内JSON格式数据的处理办法

原标题:3分钟短文:Laravel请求体内JSON格式数据的处理办法引言前几篇文章我们讲了表单数据的接收,验证等功能。也说到了传送的数组如何处理, 今天我们说一下如果传送的数据是JSON格式,其处理流程。学习时间如果知道传入…

python数据批量写入iq数据库_通过Load table命令将数据文件加载到Sybase IQ数据库里面的Python脚本...

CREATE TABLE poc_app.sys_ftp_cfg(ftp_id varchar(100) NOT NULL, --话单文件名标记ftp_cycle_id varchar(1) NOT NULL, --话单文件名周期ftp_stage_filepath varchar(255) NOT NULL, --话单处理后路径ftp_stage_filereg …

监听某个区域滚动_监听页面滚动及滚动到指定位置

一、原生js通过window.onscroll监听window.onscroll function() {//为了保证兼容性,这里取两个值,哪个有值取哪一个//scrollTop就是触发滚轮事件时滚轮的高度var scrollTop document.documentElement.scrollTop || document.body.scrollTop;console.lo…

mysql 14.12_MySQL必知必会12-14 汇总 分组 子查询

12 汇总数据-用聚集类函数用于诸如:表中的行数、表中行组的和、列中的最大值平均值等。(python的dataframe 在输出此类结果时有优势)MySQL 五个聚集函数(其它还有:标准偏差聚集函数等)AVG()COUNT()MAX()MIN()SUM()SELECT AVG(alltotal) FROM yc_tmp;SELE…

mysql jdbc 绑定变量_jdbc测试mysql数据库sql预解析(绑定变量)

jdbc测试mysql数据库sql预解析(绑定变量)用习惯了oracle,学习mysql,想测试一下mysql绑定变量的效果。以前看网上介绍大部份都说mysql没有sql共享池的概念,所以也不存在sql预解析或绑定变量的说法。今天测试了一下(通过网络抓包、查看服务器端…

mysql错误码1709_MySQL5.6出现ERROR 1709 (HY000): Index column size too large问题的解决方法...

一、问题mysql 5.6 出现如下问题:[ERROR 1709 (HY000): Index column size too large. The maximum column size is 767 bytes.]二、解决根据文档所述Prefix support and lengths of prefixes (where supported) are storage engine dependent. For example, a pref…

sublime python插件配置_sublime text 3 + python配置,完整搭建及常用插件安装

四年的时间,一直使用EmEditor编辑器进行Python开发,之前是做面向过程,只需要将一个单独的py文件维护好即可,用着也挺顺手,但是最近在做面向对象的开发,不同的py文件中相互关联较多,感觉单纯使用…

java中trim_java中string.trim()函数的作用实例及源码

trim()的作用:去掉字符串首尾的空格。public static void main(String arg[]){String a" hello world ";String b"hello world";System.out.println(b.equals(a));aa.trim();//去掉字符串首尾的空格System.out.println(a.equals(b));}执行结果&…

java 开发详解_面向接口编程详解-Java篇

相信看到这篇文字的人已经不需要了解什么是接口了,我就不再过多的做介绍了,直接步入正题,接口测试如何编写。那么在这一篇里,我们用一个例子,让各位对这个重要的编程思想有个直观的印象。为充分考虑到初学者&#xff0…