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

通过我自己的一番实战,可以确定的是,只要创建表,这个rowid一定是存在的,唯一区别就是显示和隐士的区别,也就是是否可以通过select_rowidfromtable查询出来那么问题来了,哪些情况下rowid是显示的?1、当表中有主键并且是数值型的时候才是显示的2、当表中没有主键的时候,但是表中有唯一非空并且是数值型的时候才是显示的接下来,创建表来实战看下,是否是这样的

先创建一个带有主键并且是数值型的表createtablez1(idbigint(20)primarykey)engine=innodb;

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

再创建一个没有主键但是有唯一键并且是数值型非空的表createtablez3(nameint(11)notnull,unique(name))engine=innodbcharset=utf8

此时再创建一个没有主键,并且有唯一键,但是可以为空或者不是数值型的表createtablez4(namevarchar(11)notnull,unique(name))engine=innodbcharset=utf8;createtablez5(nameint(11),unique(name))engine=innodbcharset=utf8;


再来看看官网咋说的,再理解下官网连接:https://dev.mysql.com/doc/refman/5.7/en/create-index.htmlIfatablehasaPRIMARYKEYorUNIQUENOTNULLindexthatconsistsofasinglecolumnthathasanintegertype,youcanuse_rowidtorefertotheindexedcolumninSELECTstatements,asfollows:_rowidreferstothePRIMARYKEYcolumnifthereisaPRIMARYKEYconsistingofasingleintegercolumn.IfthereisaPRIMARYKEYbutitdoesnotconsistofasingleintegercolumn,_rowidcannotbeused.Otherwise,_rowidreferstothecolumninthefirstUNIQUENOTNULLindexifthatindexconsistsofasingleintegercolumn.IfthefirstUNIQUENOTNULLindexdoesnotconsistofasingleintegercolumn,_rowidcannotbeused.

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

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


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

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

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

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

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