掌握mysql隐藏字段(rowid)什么时候是可见的


本文摘自PHP中文网,作者coldplay.xixi,侵删。

相关免费学习推荐:mysql视频教程

在这里插入图片描述

1

2

3

4

5

通过我自己的一番实战,可以确定的是,只要创建表,这个rowid一定是存在的,唯一区别就是显示和隐士的区别,也就是是否可以通过select _rowid from table查询出来

那么问题来了,哪些情况下rowid是显示的?

1 、当表中有主键并且是数值型的时候才是显示的

2、当表中没有主键的时候,但是表中有唯一非空并且是数值型的时候才是显示的

接下来,创建表来实战看下,是否是这样的

1

2

3

4

先创建一个带有主键并且是数值型的表

create table  z1(

id bigint(20) primary key

)engine=innodb;

在这里插入图片描述

1

2

3

4

再创建一个带有主键不是数值型的表(虽然业务不会这样创建,只是为了证明rowid)

create table  z2(

name varchar(20) primary key

)engine=innodb;

在这里插入图片描述

1

2

3

4

5

再创建一个没有主键但是有唯一键并且是数值型非空的表

create table z3(

    name int(11) not null,

    unique(name)

)engine=innodb charset=utf8

在这里插入图片描述

1

2

3

4

5

6

7

8

9

此时再创建一个没有主键,并且有唯一键,但是可以为空或者不是数值型的表

create table z4(

   name varchar(11) not null,

   unique(name)

)engine=innodb charset=utf8;

create table z5(

   name int(11) ,

   unique(name)

)engine=innodb charset=utf8;

在这里插入图片描述
在这里插入图片描述

1

2

3

4

5

6

7

再来看看官网咋说的,再理解下

官网连接:https://dev.mysql.com/doc/refman/5.7/en/create-index.html

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, as follows:

 

_rowid refers to the PRIMARY KEY column if there is a PRIMARY KEY consisting of a single integer column. If there is a PRIMARY KEY but it does not consist of a single integer column, _rowid cannot be used.

 

Otherwise, _rowid refers to the column in the first UNIQUE NOT NULL index if that index consists of a single integer column. If the first UNIQUE NOT NULL index does not consist of a single integer column, _rowid cannot be used.

1

此时我再创建一个表,表中只有一个字段,并且是字符串类型的,看下生成的隐式rowid,达到最大值会发生什么?(注意此时底层会默认生成一个6字节的指针,最大值为2^48 次幂)

在这里插入图片描述

1

2

3

4

此时用gdb工具让rowid达到最大值再插入看看会怎么样?

     答:先找到mysqld的进程pid,命令

      ps aux | grep mysqld

     gdb -p 你的mysql的pid -ex 'p dict_sys->row_id=1' -batch

在这里插入图片描述
在这里插入图片描述

1

可以看到此时插入了3条数据

在这里插入图片描述

1

2

这个时候把rowid变为2^48次幂之后,再插入看下效果

gdb -p 29410 -ex 'p dict_sys->row_id=281474976710656' -batch

在这里插入图片描述

1

此时再插入三条数据,此时a1 a2被覆盖了,所以在不满足上述二种情况的时候,生成的隐式rowid在用尽之后,之前的记录会被覆盖,所以创建表一定要有主键id,避免发生覆盖,虽然概率比较低,这个只是用主键的其中一个原因哈

在这里插入图片描述

1

所以综上所述:看我xmind那个总结,自己再理解消化下吧。

以上就是掌握mysql隐藏字段(rowid)什么时候是可见的的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

mysql怎么输入datetime型的数据

mysql-bin是什么文件?

mysql中的乐观锁,悲观锁和mvcc全面解析

基于mysql查询语句的使用详解

mysql prepare语句的sql语法

mysql8.0.29安装配置方法图文教程

mysql配置参数的详细介绍

mysql学习之事务控制

java使用intellij idea连接mysql的详细教程

mysql能存储多少条数据

更多相关阅读请进入《mysql》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...