mysql隐藏字段rowid在什么时候是可见的
发表于:2025-11-09 作者:千家信息网编辑
千家信息网最后更新 2025年11月09日,今天小编给大家分享的是mysql隐藏字段rowid在什么时候是可见的,相信很多人都不太了解,为了让大家更加了解,所以给大家总结了以下内容,一起往下看吧。一定会有所收获的哦。通过我自己的一番实战,可以确
千家信息网最后更新 2025年11月09日mysql隐藏字段rowid在什么时候是可见的
今天小编给大家分享的是mysql隐藏字段rowid在什么时候是可见的,相信很多人都不太了解,为了让大家更加了解,所以给大家总结了以下内容,一起往下看吧。一定会有所收获的哦。

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

此时再创建一个没有主键,并且有唯一键,但是可以为空或者不是数值型的表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;
再来看看官网咋说的,再理解下官网连接:https://dev.mysql.com/doc/refman/5.7/en/create-index.htmlIf 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 次幂)
此时用gdb工具让rowid达到最大值再插入看看会怎么样? 答:先找到mysqld的进程pid,命令 ps aux | grep mysqld gdb -p 你的mysql的pid -ex 'p dict_sys->row_id=1' -batch
可以看到此时插入了3条数据
这个时候把rowid变为2^48次幂之后,再插入看下效果gdb -p 29410 -ex 'p dict_sys->row_id=281474976710656' -batch
此时再插入三条数据,此时a1 a2被覆盖了,所以在不满足上述二种情况的时候,生成的隐式rowid在用尽之后,之前的记录会被覆盖,所以创建表一定要有主键id,避免发生覆盖,虽然概率比较低,这个只是用主键的其中一个原因哈
所以综上所述:看我xmind那个总结,自己再理解消化下吧。
关于mysql隐藏字段rowid在什么时候是可见的就分享到这里了,希望以上内容可以对大家有一定的参考价值,可以学以致用。如果喜欢本篇文章,不妨把它分享出去让更多的人看到。
时候
数值
字段
最大
最大值
生成
内容
只是
实战
情况
数据
学以致用
接下来
下官
业务
也就是
价值
原因
只有
可以通过
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
长春瑞鹏网络技术有限公司
福建运营软件开发厂家
计算机网络技术入门编程
涪陵区一站式软件开发服务特点
cors服务器测量
世界三大生物信息学数据库
服务器安全防护系统带联锁功能
北京金山云网络技术有限公司简介
什么是全服服务器
大型数据库技术课程
服务器 boot uefi
完整的软件开发编码流程
华为5g物联网网络安全合作商
戴尔服务器r620装系统教程
龙华网络安全建设找哪家
华为网络安全待遇
重庆交友软件开发哪家便宜
恐怖主义是当前世界网络安全
当然翻译软件开发
软件编程软件开发怎么样
爱心宠物之家数据库UID图
sql连接数据库软件
邯郸办公系统软件开发哪家正规
高校的网络安全责任
网络技术中钓鱼是什么意思
大数据库课后习题
漫说网络安全法四
卢一涛网络安全
职业中专网络安全技术试题
联想服务器td340机箱怎么开