Navicat使用教程:获取MySQL中的行数(第1部分)
下载Navicat Premium最新版本
Navicat Premium是一个可连接多种数据库的管理工具,它可以让你以单一程序同时连接到MySQL、Oracle及PostgreSQL数据库,让管理不同类型的数据库更加的方便。
在MySQL中有几种获取行数的方法。一些数据库管理产品提供数据库统计信息,如表大小,但也可以使用直接的SQL来完成。在这篇文章中,我们将使用本机COUNT()函数来检索MySQL数据库中一个表或视图中的行数。在第2部分中,我们将学习如何从多个表甚至从数据库中的所有表中获取行计数。
COUNT()函数的多种形式
您可能已经知道COUNT()函数返回表中的行数。但是还有一点要比这个多,因为COUNT()函数可以用来计算表中的所有行,或者只计算那些符合特定条件的行。秘密在函数签名中,它有几种形式:COUNT(*)、COUNT(expression)和COUNT(DISTINCT expression)。
在每种情况下,COUNT()都返回一个BIGINT,该BIGINT包含匹配行的数量,如果未找到匹配行,则返回零。
对表中的所有行进行计数
要对表中的所有行进行计数,无论它们是否包含空值,请使用COUNT(*)。该形式的COUNT()函数基本上返回由SELECT语句返回的结果集中的行数。
1
SELECT COUNT(*) FROM cities;
像上面这样的语句,在没有WHERE子句或附加列的情况下调用COUNT(*)函数,将在MyISAM表上执行得非常快,因为行数存储在information_schema数据库的Tables表的Table_Rows列中。
对于事务性存储引擎(如InnoDB),存储精确的行计数是有问题的,因为InnoDB不在表中保留行的内部计数。如果是这样,并发事务可能会同时“看到”不同数量的行。因此,SELECT COUNT(*)语句只对当前事务可见的行进行计数。这意味着,在繁重的工作负载期间使用COUNT(*) 运行查询可能会导致数字稍微不准确。
只对具有COUNT(expr)的非空行进行计数
不向COUNT()传递任何内容将执行函数的COUNT(expr)版本,但sans参数除外。这样调用COUNT()只返回不包含空值的行。例如,假设我们有一个名为code_values的简单表:
public ushort TransactionIdentifier { get; set; }
public ushort ProtocolIdentifier { get; set; }
public ushort Length { get; set; }
public short UnitIdentifier { get; set; }
public ModbusHeader(IByteBuffer buffer)
{
TransactionIdentifier = buffer.ReadUnsignedShort();
ProtocolIdentifier = buffer.ReadUnsignedShort();
Length = buffer.ReadUnsignedShort();
UnitIdentifier = buffer.ReadByte();
}
public ModbusHeader(www.fengshen157.com/ ushort transactionIdentifier, short unitIdentifier)
: this(transactionIdentifier, 0x0000,www.gcyL157.com unitIdentifier) // for modbus protocol:www.michenggw.com Protocol Identifier = 0x00
{
}
private ModbusHeader(www.dasheng178.com ushort www.mcyllpt.com transactionIdentifier, ushort protocolIdentifier, short unitIdentifier)
{
TransactionIdentifier = transactionIdentifier;
ProtocolIdentifier = protocolIdentifier;
UnitIdentifier = unitIdentifier;
}
public IByteBuffer Encode()
{
IByteBuffer buffer = Unpooled.Buffer();
buffer.WriteUnsignedShort(TransactionIdentifier);
buffer.WriteUnsignedShort(ProtocolIdentifier);
buffer.WriteUnsignedShort(Length);
buffer.WriteByte(UnitIdentifier);
code_values
+-------+
| code |
+-------+
| 1 |
+-------+
| |
+-------+
| |
+-------+
| 4 |
+-------+
从表中选择COUNT()将返回2,即使有4行:
SELECT COUNT(*) FROM code_values;
+---------+
| COUNT() |
+---------+
| 2 |
+---------+
请注意,很少使用此版本的COUNT()函数,因为在规范化的数据库中,空行不应该是问题,这种情况只有在表没有主键时才会发生。在大多数情况下,COUNT(*)都可以正常工作。
当然,COUNT(expr)确实接受正确的表达式。下面是另一个同样获取空行和非空行的查询:
1
SELECT COUNT(IFNULL(code, 1)) FROM code_values;
计算非空值
COUNT函数的COUNT(expr)版本还接受单个列名,其效果是COUNT(column_name)将返回column_name不为空的记录数。因此,以下SELECT查询将获取描述列包含非空值的行数:
1
SELECT COUNT(description) FROM widgets;
在第2部分中,我们将学习如何使用COUNT(DISTINCT expression)签名以及如何从多个表中获取行计数。
Navicat使用教程:获取MySQL中的行数(第1部分)的更多相关文章
- 【2017-06-29】在登录页面自动返回上次请求页面、Js获取table中的行数与列数
一.在登录页面自动返回上次请求页面 Request.UrlReferrer比如 if (Request.UrlReferrer != null) { //如果能获取来路地址 Response.Redi ...
- mysql获取表中数据行数
获取单个表的行数 使用count(*)或者count(1) SELECT count(1) AS count FROM table_name; 执行结果 获取两个表的行数 使用union组合每个sel ...
- MySQL中查询行数最多的表并且排序
#切换到schema use information_schema; #查询数据量最大的30张表 并排序 select table_name,table_rows from tables order ...
- Navicat使用教程:获取MySQL中的高级行数(第2部分)
Navicat Premium是一个可连接多种数据库的管理工具,它可以让你以单一程序同时连接到MySQL.Oracle及PostgreSQL数据库,让管理不同类型的数据库更加的方便. 在上篇文章中,我 ...
- [数据库事务与锁]详解五: MySQL中的行级锁,表级锁,页级锁
注明: 本文转载自http://www.hollischuang.com/archives/914 在计算机科学中,锁是在执行多线程时用于强行限制资源访问的同步机制,即用于在并发控制中保证对互斥要求的 ...
- 【数据库】数据库的锁机制,MySQL中的行级锁,表级锁,页级锁
转载:http://www.hollischuang.com/archives/914 数据库的读现象浅析中介绍过,在并发访问情况下,可能会出现脏读.不可重复读和幻读等读现象,为了应对这些问题,主流数 ...
- MySQL中的行级锁,表级锁,页级锁
在计算机科学中,锁是在执行多线程时用于强行限制资源访问的同步机制,即用于在并发控制中保证对互斥要求的满足. 在数据库的锁机制中介绍过,在DBMS中,可以按照锁的粒度把数据库锁分为行级锁(INNODB引 ...
- 【转】MySQL中的行级锁,表级锁,页级锁
在计算机科学中,锁是在执行多线程时用于强行限制资源访问的同步机制,即用于在并发控制中保证对互斥要求的满足. 在数据库的锁机制中介绍过,在DBMS中,可以按照锁的粒度把数据库锁分为行级锁(INNODB引 ...
- 转 MySQL中的行级锁,表级锁,页级锁
对mysql乐观锁.悲观锁.共享锁.排它锁.行锁.表锁概念的理解 转载. https://blog.csdn.net/puhaiyang/article/details/72284702 实验环境 ...
随机推荐
- JUC——并发集合类
如果要进行多个数据的保存,无疑首选类集(List.Set.Queue.Map),在类集的学习的时候也知道一个概念:许多集合的子类都具有同步与异步的差别,但是如果真的要在多线程之中去使用这些类,是否真的 ...
- DMA-Direct Memory Access
什么是? DMA 首先它是一种数据的传输方式:其次传输包括从设备到内存.内存到存储.内存到内存等:最后,它是在不经过cpu的情况下实现数据传输.. DAM主要有共享缓存DMA,Scatter/Gath ...
- C#多线程的几种使用
参见链接 :http://www.jb51.net/article/46234.htm
- ReLU——Deep Sparse Rectifier Neural Networks
1. 摘要 ReLU 相比 Tanh 能产生相同或者更好的性能,而且能产生真零的稀疏表示,非常适合自然就稀疏的数据. 采用 ReLU 后,在大量的有标签数据下,有没有无监督预训练模型取得的最好效果是一 ...
- Leetcode_3. Find the longest substring without repeating characters
3. Find the longest substring without repeating characters Given a string, find the length of the lo ...
- eclipse xml文件中按alt+/没有提示信息
转载地址:http://blog.sina.com.cn/s/blog_972ddc1b01012mmh.html 今天要写这篇博文是因为遇到这样的不是技术的问题,但找到问题根源再解决这个问题又花费很 ...
- Java时间格式的使用,bug难时真是坑
很简单的问题,尤其是新手开发,要多自己动手写代码,都说程序猿大都是程序的搬用工,其实不然,好的写手,和差的写手,区别就在是不是会花时间读读代码,并且自己动手实践一下,其实一个程序范这样的错误,绝对是低 ...
- “秒杀”问题的数据库和SQL设计【转载】
“秒杀”问题的数据库和SQL设计 APRIL 21ST, 2015 问题的来源 完全不考虑一致性的方案 表结构 方案 存在的问题 保证单用户不会重复购买 解决超卖问题 方案 优化 提高性能了 鱼与熊掌 ...
- dazhewang数据库初设计
mysql> use dazhe; Database changed mysql> create table shops(id int primary key auto_increment ...
- 信息安全C散列函数的应用及其安全性2016011992
1:散列函数的具体应用 使用一个散列函数可以很直观的检测出数据在传输时发生的错误. MD5 Hash算法的"数字指纹"特性,使它成为目前应用最广泛的一种文件完整性校验(Checks ...