mysql隐藏字段rowid在什么时候是可见的
发表于:2025-01-22 作者:千家信息网编辑
千家信息网最后更新 2025年01月22日,今天小编给大家分享的是mysql隐藏字段rowid在什么时候是可见的,相信很多人都不太了解,为了让大家更加了解,所以给大家总结了以下内容,一起往下看吧。一定会有所收获的哦。通过我自己的一番实战,可以确
千家信息网最后更新 2025年01月22日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安全错误
数据库的锁怎样保障安全
浙江前程网络技术有限公司
河南普惠网络技术怎么样
中国电信中网络技术工程师
龙芯电脑支持的软件开发环境
什么是完全数据库备份与恢复
宁波软件开发驻场哪家可靠
南京科远数据库管理器密码
微软公司网络安全部门
金税盘数据库错误
软件开发方法学包括
中央网络安全新闻官网
数据库中字段为空怎么表示
成都软件开发驻场哪家专业
软件开发delphi
随州iptv服务器预算
磁力解析软件开发
数据库软件怎么学
数据库与web技术就业
山东省金乡县网络安全
南京市网络安全先进学校
vb动态数据库连接
投影电视显示无法访问服务器
软件开发需求验证的行动
海南毅鑫网络技术有限公司
exe软件服务器打不开
海康服务器能接多少摄像头
深圳能耗管理软件开发
湖南新一代软件开发推广
密集型服务器管理方案
宝德自强服务器组raid