当前位置: 首页 > news >正文

合肥的网站建设州做dj网站用什么建站系统比较好

合肥的网站建设州,做dj网站用什么建站系统比较好,正邦集团招聘,热门图片素材MySQL select count(*)、count(1)、count(列名) 的区别? 这里我们先给出正确结论: count(*),包含了所有的列,会计算所有的行数,在统计结果时候,不会忽略列值为空的情况。count(1),忽略所有的列…

MySQL select count(*)、count(1)、count(列名) 的区别?

这里我们先给出正确结论:

  • count(*),包含了所有的列,会计算所有的行数,在统计结果时候,不会忽略列值为空的情况。
  • count(1),忽略所有的列,用常量 1 代表所有的行,也不会忽略列值为1的数据,统计结果和count(*) 一致。
  • count(列名),只统计指定列名的那一行数据数据,在统计结果的时候会忽略列值为空的行。

下面我们证明:

 select count(*) from  user;
select count(1) from  user;
select count(age) from  user;

SQL执行结果:

在这里插入图片描述
列值没有为空的时候,三种查询结果一致。

下面我们设置 id 为1 的age 为null:

update user set age=null where id = 1;

再次执行查询:

 select count(*) from  user;
select count(1) from  user;
select count(age) from  user;

查询结果:

在这里插入图片描述
总结分析:

  • 从结果来看 count(*)、count(1) 没有区别,不排除列为NULL 的行。
  • count (列名)会过滤空值。

结论正确。

select count(*) 会造成全表扫描吗?

会吗?如果在面试中,你回答会扫描全表,那不好意思,可能面试官只能要你回去等通知了。
话不多说,验证如下:

explain select count(*) from data_memory;

在这里插入图片描述

分析执行计划:

  • key有值,明显使用了索引。
  • type:index,只扫描了索引树,并非是ALL 全表扫描。

分析执行计划可知,select count(*) 不会造成全表扫描。

一文看懂执行计划传送门:
MySQL–explain执行计划详解

select count(*)、count(1)、count(列名) 的执行效率区别?

分别验证:

select count(*) from data_memory;

结果:

在这里插入图片描述

select count(1) from data_memory;

结果:

在这里插入图片描述

select count(ocp_id) from data_memory;

结果:

在这里插入图片描述

结论:

  • 如果表中只有一列,count(*) 的效率最佳。
  • 如果表有多列,且存在主键,count (列名)效率最佳,效率一次是:count (列名)>count (1) >count( *)。
  • 如果表有多列,且不存在主键,则count(1 )效率优于count( *)。

select count(*)、count(1)、count(列名) 在开发中如何选择?

阿里巴巴Java开发手册是如下描述的:

【强制】不要使用 count(列名)或 count(常量)来替代 count(), count()是 SQL92 定义的 标准统计行数的语法,跟数据库无关,跟 NULL 和非 NULL 无关。
说明: count(*)会统计值为 NULL 的行,而count(列名)不会统计此列为 NULL 值的行。

  • 我们在开发中如果需要用到count()聚合函数,那么优先考虑count(),因为 MySQL 本身对 count() 做了很多优化处理。
  • count(列) 的时候,需要注意,如果列没有建立索引,那 count(列) 会导致全表扫描。
  • 同样 count(*) 统计的 where 子句的查询条件列如果没有索引,也会导致全表扫描。

count()函数使用小建议:无特殊要求的时候,建议无脑使用 count(*)。

如有不正确的地方请各位指出纠正。

http://www.yayakq.cn/news/173919/

相关文章:

  • 做微商推广有哪些好的分类信息网站北京做手机网站的公司
  • 手机端微网站设计模板制作 网页
  • 三网合一网站建设程序做做网站
  • 创办一个网站的流程宿州建设网站公司
  • 金融贷款和网站建设哪个赚钱千瓜数据
  • 山西运城网站建设兰州市网络公司
  • 深圳沙井做网站外包做网站平台 一分钟
  • 如何自己搭建一个企业网站在线免费做logo印章网站
  • 阳江网站建设 公司价格中关村在线手机参数
  • 帝国网站采集管理怎么做做网站首页的图片素材
  • 网站做美食视频挣钱吗哪里找网站开发团队
  • 请问番禺哪里有做网站的阿里云服务器搭建wordpress
  • 网站开发版本号写作网站官方
  • 17网站一起做网店 睡衣科凡全屋定制
  • 在线商城网站建设百度快照官网
  • 网站开发与维护视频教程初中生怎么提升学历
  • 2021免费正能量网站入口佛山论坛建站模板
  • 软件开发设计流程图优化营商环境应当坚持什么原则
  • 怎么自己做代刷网站手机wap版网站制作
  • 合肥百姓网网站建设网站开发的外文翻译
  • 有哪些游戏可以做网站唐山网络运营推广
  • php网站建设哪家好高明做网站
  • 站长工具亚洲高端网站特色
  • 网站统计平台洛阳网络推广公司
  • 织梦网站修改教程西安推广公司无网不胜
  • 厦门网站建设模拟网络公司是什么意思
  • 宝安多屏网站建设公司好吗mvc 网站路径
  • wordpress文章采集发布插件搜索引擎seo如何优化
  • html5 网站模板 米卖房app十大排行榜
  • 做音乐头像网站博州住房和城乡建设部网站