在介绍mysql的多版本并发控制MVCC的过程中,我们提到过mysql中存在一些隐藏列,例如行标识、事务ID、回滚指针等,不知道大家是否和我一样好奇过,要怎样才能实际地看到这些隐藏列的值呢?

本文我们就来重点讨论一下诸多隐藏列中的行标识DB_ROW_ID,实际上,将行标识称为隐藏列并不准确,因为它并不是一个真实存在的列,DB_ROW_ID实际上是一个非空唯一列的别名。在拨开它的神秘面纱之前,我们看一下官方文档的说明:

If a table has a PRIMARY KEY or UNIQUE NOT NULL index that consists of a single column that has an integer type, you can use _rowid to refer to the indexed column in SELECT statements

简单翻译一下,如果在表中存在主键或非空唯一索引,并且仅由一个整数类型的列构成,那么就可以使用SELECT语句直接查询_rowid,并且这个_rowid的值会引用该索引列的值。

着重看一下文档中提到的几个关键字,主键、唯一索引、非空、单独一列、数值类型,接下来我们就要从这些角度入手,探究一下神秘的隐藏字段_rowid。

1、存在主键
先看设置了主键且是数值类型的情况,使用下面的语句建表:

CREATE TABLE `table1` (`id` bigint(20) NOT NULL PRIMARY KEY ,`name` varchar(32) DEFAULT NULL
) ENGINE=InnoDB;

插入三条测试数据后,执行下面的查询语句,在select查询语句中直接查询_rowid:

select *,_rowid from table1

查看执行结果,_rowid可以被正常查询:

可以看到在设置了主键,并且主键字段是数值类型的情况下,_rowid直接引用了主键字段的值。对于这种可以被select语句查询到的的情况,可以将其称为显式的rowid。

回顾一下前面提到的文档中的几个关键字,再考虑其他情况。由于主键必定是非空字段,下面来看一下主键是非数值类型字段的情况,建表如下:

CREATE TABLE `table2` (`id` varchar(20) NOT NULL PRIMARY KEY ,`name` varchar(32) DEFAULT NULL
) ENGINE=InnoDB;

在table2执行上面相同的查询,结果报错无法查询_rowid,也就证明了如果主键字段是非数值类型,那么将无法直接查询_rowid。

2、无主键,存在唯一索引
上面对两种类型的主键进行了测试后,接下来我们看一下当表中没有主键、但存在唯一索引的情况。首先测试非空唯一索引加在数值类型字段的情况,建表如下:

CREATE TABLE `table3` (`id` bigint(20) NOT NULL UNIQUE KEY,`name` varchar(32)
) ENGINE=InnoDB;

查询可以正常执行,并且_rowid引用了唯一索引所在列的值:

唯一索引与主键不同的是,唯一索引所在的字段可以为NULL。在上面的table3中,在唯一索引所在的列上添加了NOT NULL非空约束,如果我们把这个非空约束删除掉,还能显式地查询到_rowid吗?下面再创建一个表,不同是在唯一索引所在的列上,不添加非空约束:

CREATE TABLE `table4` (`id` bigint(20) UNIQUE KEY,`name` varchar(32)
) ENGINE=InnoDB;

执行查询语句,在这种情况下,无法显式地查询到_rowid:

和主键类似的,我们再对唯一索引被加在非数值类型的字段的情况进行测试。下面在建表时将唯一索引添加在字符类型的字段上,并添加非空约束:

CREATE TABLE `table5` (`id` bigint(20),`name` varchar(32) NOT NULL UNIQUE KEY
) ENGINE=InnoDB;

同样无法显示。
针对上面三种情况的测试结果,可以得出结论,当没有主键、但存在唯一索引的情况下,只有该唯一索引被添加在数值类型的字段上,且该字段添加了非空约束时,才能够显式地查询到_rowid,并且_rowid引用了这个唯一索引字段的值。

眼见为实,来瞧瞧MySQL中的隐藏列!相关推荐

  1. 眼见为实,看看MySQL中的隐藏列

    在介绍mysql的多版本并发控制mvcc的过程中,我们提到过mysql中存在一些隐藏列,例如行标识.事务ID.回滚指针等,不知道大家是否和我一样好奇过,要怎样才能实际地看到这些隐藏列的值呢? 本文我们 ...

  2. MySQL中的隐藏列!_rowid

    在介绍mysql的多版本并发控制 MVCC 的过程中,我们提到过mysql中存在一些隐藏列,例如 行标识. 事务ID. 回滚指针等,不知道大家是否和我一样好奇过,要怎样才能实际地看到这些隐藏列的值呢? ...

  3. mysql 临时列_如何在MySQL中列出临时表列?

    要列出MySQL中的临时表列,让我们首先创建一个临时表. 这是一个例子.我们创建了一个临时表,其中包含一些列,其中包括学生的详细信息-mysql> CREATE TEMPORARY TABLE  ...

  4. 在MySQL中的特定列之后添加多个列

    本文翻译自:Adding multiple columns AFTER a specific column in MySQL I need to add multiple columns to a t ...

  5. MySql中关于某列中相同数值连续出现次数的统计

    MySql中关于某列中相同数值连续出现次数的统计 原表如下: www.2cto.com 100 101 102 100 100 103 104 102 102 105 106 101 101 输出如下 ...

  6. 报表中利用隐藏列对扩展格显示值求和

    在润乾报表中,获取报表中单元格显示值的函数是disp(),然而这个函数却无法计算扩展单元格的显示值.从而无法直接对扩展个显示值求和. 在下图中,需要计算D3单元格的显示值之和. D3值为:ds1.再订 ...

  7. html中怎样隐藏列,关于jquery:隐藏/显示HTML表中的列

    我有一个包含几列的HTML表,我需要使用jquery实现一个列选择器. 当用户单击复选框时,我要隐藏/显示表中的相应列. 我想在不将类附加到表中的每个td的情况下执行此操作,是否可以使用jquery选 ...

  8. 如何选择MySQL中除一列外的所有列

    SQL通过SELECT *(SELECT ALL)子句使选择表中的所有字段变得非常简单.不幸的是,一旦您从列表中删除了一列,SELECT ALL语句就会消失.写出每个列的名称很快就会变得乏味,尤其是当 ...

  9. nvarchar在mysql中是_如何在MySQL中创建NVARCHAR列?

    MySQL转换NVARCHAR()为VARCHAR().NVARCHAR在MySQL中代表National Varchar.让我们首先创建一个表,其中" StudentName"列 ...

最新文章

  1. Excel数据拆分-分列
  2. JS定时器和单线程异步特性
  3. EasyExcel(笔记)
  4. 大数据_Flink_数据处理_运行时架构4_作业调度原理及思考问题---Flink工作笔记0019
  5. 取消IDEA保存文件,默认删除行尾空格
  6. app自动化测试之Appium 源码分析
  7. 七:动态规划-数字三角形
  8. node.js学习文档_学习NodeJs从每天一个小知识点开始
  9. Oracle使用sqluldr2
  10. 3dmax2014 uv用法_3dmax中UV贴图的使用方法
  11. pdf转jpg的在线与用转换器的转换方法
  12. sdut 1299 最长上升子序列
  13. 域名dns被劫持怎么办、dns被劫持怎么办、dns被劫持的解决方法
  14. ZigBee Dotdot
  15. 0102Linux基础命令
  16. 融云根据关键字获取搜索聊天记录
  17. 大数据最佳实践-flink
  18. 查找1至100的素数
  19. 3GPP TS 23501-g51 中英文对照 | 4.4.4 Location services
  20. python选择哪个版本-Python下载哪个版本比较好?

热门文章

  1. 【Android】Audio音频输出通道切换 - 蓝牙bluetooth、外放
  2. 一些网页制作的小模板,个人收藏用(持续更新)
  3. 安装了显卡驱动但是无法使用nvidia-smi?
  4. java8中stream流解决两个list合并问题
  5. HLS第十三课(bayer video)
  6. mac 锁屏快捷键与qq的快捷键冲突 command + control + q
  7. 直播回顾|基于TESSY的测试用例自动化评估与优化
  8. Cookie、session和localStorage、以及sessionStorage之间的区别
  9. 大数据时代,你还为数据单位,而困惑么? 计算机存储单位:Byte、KB、MB、GB、TB、PB、EB分别叫什么?他们的进率是多少?
  10. WGAN-GP:进阶的WGAN