今天小编给大家分享的是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.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 次幂)此时用gdb工具让rowid达到最大值再插入看看会怎么样? 答:先找到mysqld的进程pid,命令 ps aux | grep mysqld gdb -p 你的mysql的pid -ex 'p dict_sys->row_id=1' -batch
可以看到此时插入了3条数据
郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,多谢。