Heim > Datenbank > MySQL-Tutorial > Hauptteil

Master, wenn versteckte MySQL-Felder (rowid) sichtbar sind

coldplay.xixi
Freigeben: 2021-01-12 09:06:12
nach vorne
4867 Leute haben es durchsucht

Master, wenn versteckte MySQL-Felder (rowid) sichtbar sind

Verwandte kostenlose Lernempfehlungen: MySQL-Video-Tutorial

Master, wenn versteckte MySQL-Felder (rowid) sichtbar sind

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

Master, wenn versteckte MySQL-Felder (rowid) sichtbar sind

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

Master, wenn versteckte MySQL-Felder (rowid) sichtbar sind

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

Master, wenn versteckte MySQL-Felder (rowid) sichtbar sind

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

Master, wenn versteckte MySQL-Felder (rowid) sichtbar sind
Master, wenn versteckte MySQL-Felder (rowid) sichtbar sind

再来看看官网咋说的,再理解下
官网连接: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.
Nach dem Login kopieren
此时我再创建一个表,表中只有一个字段,并且是字符串类型的,看下生成的隐式rowid,达到最大值会发生什么?(注意此时底层会默认生成一个6字节的指针,最大值为2^48 次幂)
Nach dem Login kopieren

Master, wenn versteckte MySQL-Felder (rowid) sichtbar sind

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

Master, wenn versteckte MySQL-Felder (rowid) sichtbar sind
Master, wenn versteckte MySQL-Felder (rowid) sichtbar sind

可以看到此时插入了3条数据
Nach dem Login kopieren

Master, wenn versteckte MySQL-Felder (rowid) sichtbar sind

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

Master, wenn versteckte MySQL-Felder (rowid) sichtbar sind

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

Master, wenn versteckte MySQL-Felder (rowid) sichtbar sind

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

Das obige ist der detaillierte Inhalt vonMaster, wenn versteckte MySQL-Felder (rowid) sichtbar sind. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:csdn.net
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!