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

网站复制图片时成绝对路径怎么学互联网怎么赚钱

网站复制图片时成绝对路径,怎么学互联网怎么赚钱,石家庄做网站百度推广,wordpress链接乱码文章目录 1. COUNT() 函数的基本作用2. COUNT(*)、COUNT(1) 和 COUNT(column) 的详细对比2.1 COUNT(*) —— 统计所有符合条件的行2.2 COUNT(1) —— 统计所有符合条件的行2.3 COUNT(column) —— 统计某一列非 NULL 的记录数 3. 性能对比3.1 EXPLAIN 分析 4. 哪种方式更好&…

文章目录

    • 1. COUNT() 函数的基本作用
    • 2. `COUNT(*)`、`COUNT(1)` 和 `COUNT(column)` 的详细对比
      • 2.1 `COUNT(*)` —— 统计所有符合条件的行
      • 2.2 `COUNT(1)` —— 统计所有符合条件的行
      • 2.3 `COUNT(column)` —— 统计某一列非 NULL 的记录数
    • 3. 性能对比
      • 3.1 `EXPLAIN` 分析
    • 4. 哪种方式更好?
      • 4.1 如果只是统计行数:
      • 4.2 统计某列的非 NULL 值:
      • 4.3 `COUNT(1)` 是否比 `COUNT(*)` 快?
    • 5. 结论
      • **最佳实践**

在 MySQL 查询优化过程中,COUNT(*)COUNT(1)COUNT(column) 这三种计数方式常常被混淆,尤其是在使用 WHERE 子句进行数据筛选时,它们的执行效率和结果可能有所不同。本文将深入解析这三者的区别,并结合 SQL 执行原理和优化策略,帮助开发者更高效地使用 COUNT() 函数。


1. COUNT() 函数的基本作用

COUNT() 是 SQL 语言中的聚合函数之一,主要用于统计符合条件的记录数。不同的 COUNT() 变体在处理 NULL 值和优化策略方面有所不同。

常见的 COUNT() 语法包括:

  • COUNT(*):统计表中所有符合条件的行(包括 NULL)。
  • COUNT(1):统计表中所有符合条件的行,与 COUNT(*) 类似。
  • COUNT(column):统计某一列中非 NULL 值的个数。

2. COUNT(*)COUNT(1)COUNT(column) 的详细对比

2.1 COUNT(*) —— 统计所有符合条件的行

COUNT(*) 计算所有符合 WHERE 条件的行数,不论这些行中的列是否包含 NULL 值。

示例:

SELECT COUNT(*) FROM users WHERE age > 18;

执行原理

  • MySQL 不会具体读取某一列的数据,而是统计符合 WHERE 条件的行数。
  • 在 InnoDB 存储引擎中,COUNT(*) 可以直接从索引中读取数据(如果合适的索引可用),性能较优。

适用场景

  • 需要统计表中所有符合条件的记录数,且不关心是否有 NULL 值时,COUNT(*) 是最佳选择。

2.2 COUNT(1) —— 统计所有符合条件的行

COUNT(1) 也是统计符合 WHERE 条件的行数,与 COUNT(*) 类似。

示例:

SELECT COUNT(1) FROM users WHERE age > 18;

执行原理

  • COUNT(1) 会在每一行返回 1,然后统计这些 1 的个数。
  • 在 MySQL 优化器看来,COUNT(1)COUNT(*) 的执行计划通常是相同的。
  • 在没有合适索引时,InnoDB 仍需进行全表扫描(或者索引扫描),不会因为 COUNT(1) 而有性能提升。

适用场景

  • COUNT(*) 作用几乎一致,但一般推荐使用 COUNT(*),因为 COUNT(*) 更符合 SQL 规范,并能适用于所有数据库系统。

2.3 COUNT(column) —— 统计某一列非 NULL 的记录数

COUNT(column) 仅统计某一列中非 NULL 的记录数,而不会统计 NULL 值。

示例:

SELECT COUNT(email) FROM users WHERE age > 18;

执行原理

  • 只有 email 列不为 NULL 的行才会被计入统计。
  • MySQL 需要读取 email 列的数据,以判断其是否为 NULL,因此比 COUNT(*)COUNT(1) 可能稍慢(如果 email 列没有索引)。

适用场景

  • 需要排除 NULL 值时,比如统计已填写 email 地址的用户数量。

3. 性能对比

为了对比 COUNT(*)COUNT(1)COUNT(column) 的性能,我们进行如下实验:

假设有一个 users 表,其中 id 为主键,email 为可能包含 NULL 的列,数据如下:

idnameageemail
1张三20zhangsan@a.com
2李四25NULL
3王五22wangwu@b.com
4赵六19NULL

测试 SQL 及其返回结果如下:

SELECT COUNT(*) FROM users WHERE age > 18;  -- 结果:3
SELECT COUNT(1) FROM users WHERE age > 18;  -- 结果:3
SELECT COUNT(email) FROM users WHERE age > 18;  -- 结果:2 (NULL 值被排除)

3.1 EXPLAIN 分析

如果 users 表的 email 没有索引,那么 COUNT(email) 需要扫描 email 列的数据,会比 COUNT(*) 略慢。

对于 COUNT(*)COUNT(1),InnoDB 通常会直接使用主键索引进行优化,因此在大多数情况下,两者性能相同。

示例 EXPLAIN 结果:

EXPLAIN SELECT COUNT(*) FROM users WHERE age > 18;
idselect_typetabletypepossible_keyskeyrowsExtra
1SIMPLEusersindexNULLPRIMARY3Using index

Using index 表示 MySQL 直接利用索引进行优化,而无需扫描所有数据。


4. 哪种方式更好?

4.1 如果只是统计行数:

  • 推荐使用 COUNT(*),因为它可以利用索引优化,并且与数据库无关,通用性更强。

4.2 统计某列的非 NULL 值:

  • 使用 COUNT(column),但要注意 NULL 值不会被计入。

4.3 COUNT(1) 是否比 COUNT(*) 快?

  • 在 MySQL 5.7 及以上版本,COUNT(1)COUNT(*) 在优化器层面已经没有明显性能差异,因此一般推荐使用 COUNT(*),更符合 SQL 规范。

5. 结论

计数方式作用处理 NULL性能优化
COUNT(*)统计符合 WHERE 条件的总行数统计所有行(包括 NULL)最优(可利用索引)
COUNT(1)统计符合 WHERE 条件的总行数统计所有行(包括 NULL)COUNT(*) 类似
COUNT(column)统计某列非 NULL 的行数只统计非 NULL 值可能稍慢(依赖索引情况)

最佳实践

  • 默认使用 COUNT(*),它性能最优且兼容性强。
  • COUNT(column) 适用于特定需求,如统计非 NULL 值个数。
  • 避免误解 COUNT(1) 更快的说法,在现代 MySQL 中它与 COUNT(*) 无本质区别。

希望这篇文章能帮助你更深入理解 MySQL 计数函数的优化策略,提高查询性能!🚀

http://www.tj-hxxt.cn/news/48023.html

相关文章:

  • 中山做展示型网站自助搭建平台
  • 招聘网站大全云建站
  • 哪些网站做批发衣服怎么做外链
  • 中国最大网站排名新站整站优化
  • 企业网站建设 知乎杭州seo俱乐部
  • 杭州市网站制作搜索引擎有哪些?
  • 模板网站建设代理商微信引流被加软件
  • 如何接做网站编程的生意中央网站seo
  • 红酒 专业 网站建设企业推广文案范文
  • 房山网站建设聚合搜索引擎入口
  • 网站建设优化一体如何让百度搜索排名靠前
  • 清河做网站报价关键路径
  • 做牛津布面料在哪个网站找客户网站优化及推广
  • 不用php做网站正规网站优化公司
  • 怎样才能在百度上搜到自己的网站六六seo基础运营第三讲
  • 付费网站推广谷歌独立站seo
  • 做电影网站被抓广告设计与制作需要学什么
  • 有没有教做蛋糕的网站seo排名是什么
  • 可以免费做网站推广的平台东莞疫情最新数据
  • 杭州科技公司网站建设百度指数大数据
  • 设计师经常看的appseo网站推广工作内容
  • 网站开发的收入关键词优化外包服务
  • 建立网站的英语鸿星尔克网络营销案例分析
  • 网站后台无ftp微信公众号怎么推广
  • 广告拍摄制作公司厦门seo排名扣费
  • 广州市建设和水务局网站百度快照搜索引擎
  • 天津市建设信息工程网sem优化服务公司
  • 长沙私人做网站微商引流推广
  • 福州网站建设加q479185700福建seo快速排名优化
  • 绍兴网站建设模板网站站长工具传媒