mysql隐藏字段rowid在什么时候是可见的

59次阅读
没有评论

共计 2000 个字符,预计需要花费 5 分钟才能阅读完成。

自动写代码机器人,免费开通

今天丸趣 TV 小编给大家分享的是 mysql 隐藏字段 rowid 在什么时候是可见的,相信很多人都不太了解,为了让大家更加了解,所以给大家总结了以下内容,一起往下看吧。一定会有所收获的哦。

mysql 隐藏字段 rowid 在什么时候是可见的

 通过我自己的一番实战,可以确定的是,只要创建表,这个 rowid 一定是存在的,唯一区别就是显示和隐士的区别,也就是是否可以通过 select _rowid from table 查询出来
那么问题来了,哪些情况下 rowid 是显示的?1 、当表中有主键并且是数值型的时候才是显示的
2、当表中没有主键的时候,但是表中有唯一非空并且是数值型的时候才是显示的
接下来,创建表来实战看下,是否是这样的 
 先创建一个带有主键并且是数值型的表
create table z1(id bigint(20) primary key 
)engine=innodb;

mysql 隐藏字段 rowid 在什么时候是可见的

 再创建一个带有主键不是数值型的表 (虽然业务不会这样创建,只是为了证明 rowid)
create table z2(name varchar(20) primary key 
)engine=innodb;

mysql 隐藏字段 rowid 在什么时候是可见的

 再创建一个没有主键但是有唯一键并且是数值型非空的表
create table z3( name int(11) not null,
 unique(name)
)engine=innodb charset=utf8

mysql 隐藏字段 rowid 在什么时候是可见的

 此时再创建一个没有主键,并且有唯一键,但是可以为空或者不是数值型的表
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;

mysql 隐藏字段 rowid 在什么时候是可见的
mysql 隐藏字段 rowid 在什么时候是可见的

 再来看看官网咋说的,再理解下
官网连接: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  次幂)

mysql 隐藏字段 rowid 在什么时候是可见的

 此时用 gdb 工具让 rowid 达到最大值再插入看看会怎么样?  答:先找到 mysqld 的进程 pid,命令
 ps aux | grep mysqld
 gdb -p  你的 mysql 的 pid -ex  p dict_sys- row_id=1  -batch

mysql 隐藏字段 rowid 在什么时候是可见的
mysql 隐藏字段 rowid 在什么时候是可见的

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

mysql 隐藏字段 rowid 在什么时候是可见的

 这个时候把 rowid 变为 2^48 次幂之后,再插入看下效果
gdb -p 29410 -ex  p dict_sys- row_id=281474976710656  -batch

mysql 隐藏字段 rowid 在什么时候是可见的

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

mysql 隐藏字段 rowid 在什么时候是可见的

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

关于 mysql 隐藏字段 rowid 在什么时候是可见的就分享到这里了,希望以上内容可以对大家有一定的参考价值,可以学以致用。如果喜欢本篇文章,不妨把它分享出去让更多的人看到。

向 AI 问一下细节

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2024-02-03发表,共计2000字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)