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

本文详细讨论了MySQL中rowid的显示条件,指出只有当表有主键且为主键类型为数值,或者无主键但有唯一非空数值型键时,rowid才会显示。通过创建不同类型的表进行实战验证,同时提到了当rowid达到最大值时,未指定主键可能导致记录被覆盖的风险。强调了创建表时设置主键的重要性。
摘要由CSDN通过智能技术生成

b7371f99ffca5ff5f222a4dbb7238d5a.png

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

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

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

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

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

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

create table z1(

id bigint(20) primary key

)engine=innodb;

6577cf8313e77c818e6577abce0d8557.png

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

create table z2(

name varchar(20) primary key

)engine=innodb;

900e5a4e2593aa3c5dc8a83b098b898b.png

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

create table z3(

name int(11) not null,

unique(name)

)engine=innodb charset=utf8

6340a3160372d4f1114c05c817f45fbb.png

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

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;

0c32de21b84dc276f5c95ecf52e2feff.png

c0062a5714730d384ec5566a7f157122.png

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

官网连接: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.

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

b3604eda953370bffc0639638266eeae.png

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

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

ps aux | grep mysqld

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

8e3c4cd97748a06401aecf054ef43ad9.png

2d55230501eb187a71a566dac157815d.png

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

38ecc36727e9d9e88b0ad4d373aa917a.png

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

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

16564928a02f46a5d421a59918279333.png

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

145f66844eddfd218ae3cbe95e9f6321.png

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值