中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

mysql隱藏字段rowid在什么時候是可見的

發布時間:2021-01-12 10:08:09 來源:億速云 閱讀:1649 作者:栢白 欄目:MySQL數據庫

今天小編給大家分享的是mysql隱藏字段rowid在什么時候是可見的,相信很多人都不太了解,為了讓大家更加了解,所以給大家總結了以下內容,一起往下看吧。一定會有所收獲的哦。

mysql隱藏字段rowid在什么時候是可見的

通過我自己的一番實戰,可以確定的是,只要創建表,這個rowid一定是存在的,唯一區別就是顯示和隱士的區別,也就是是否可以通過select _rowid from table查詢出來
那么問題來了,哪些情況下rowid是顯示的?
1 、當表中有主鍵并且是數值型的時候才是顯示的
2、當表中沒有主鍵的時候,但是表中有唯一非空并且是數值型的時候才是顯示的
接下來,創建表來實戰看下,是否是這樣的
先創建一個帶有主鍵并且是數值型的表
create table  z1(
id bigint(20) primary key 
)engine=innodb;

mysql隱藏字段rowid在什么時候是可見的

再創建一個帶有主鍵不是數值型的表(雖然業務不會這樣創建,只是為了證明rowid)
create table  z2(
name varchar(20) primary key 
)engine=innodb;

mysql隱藏字段rowid在什么時候是可見的

再創建一個沒有主鍵但是有唯一鍵并且是數值型非空的表
create table z3(
    name int(11) not null,
    unique(name)
)engine=innodb charset=utf8

mysql隱藏字段rowid在什么時候是可見的

此時再創建一個沒有主鍵,并且有唯一鍵,但是可以為空或者不是數值型的表
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;

mysql隱藏字段rowid在什么時候是可見的
mysql隱藏字段rowid在什么時候是可見的

再來看看官網咋說的,再理解下
官網連接: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 次冪)

mysql隱藏字段rowid在什么時候是可見的

此時用gdb工具讓rowid達到最大值再插入看看會怎么樣?
     答:先找到mysqld的進程pid,命令
      ps aux | grep mysqld
     gdb -p 你的mysql的pid -ex 'p dict_sys->row_id=1' -batch

mysql隱藏字段rowid在什么時候是可見的
mysql隱藏字段rowid在什么時候是可見的

可以看到此時插入了3條數據

mysql隱藏字段rowid在什么時候是可見的

這個時候把rowid變為2^48次冪之后,再插入看下效果
gdb -p 29410 -ex 'p dict_sys->row_id=281474976710656' -batch

mysql隱藏字段rowid在什么時候是可見的

此時再插入三條數據,此時a1 a2被覆蓋了,所以在不滿足上述二種情況的時候,生成的隱式rowid在用盡之后,之前的記錄會被覆蓋,所以創建表一定要有主鍵id,避免發生覆蓋,雖然概率比較低,這個只是用主鍵的其中一個原因哈

mysql隱藏字段rowid在什么時候是可見的

所以綜上所述:看我xmind那個總結,自己再理解消化下吧。

關于mysql隱藏字段rowid在什么時候是可見的就分享到這里了,希望以上內容可以對大家有一定的參考價值,可以學以致用。如果喜歡本篇文章,不妨把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

兴隆县| 聊城市| 延津县| 西和县| 卓资县| 兰坪| 布拖县| 洛川县| 丁青县| 江西省| 阳城县| 宁化县| 古交市| 三门峡市| 柳河县| 西昌市| 隆林| 密山市| 微山县| 惠东县| 鲁山县| 凤凰县| 咸宁市| 防城港市| 华阴市| 阿合奇县| 杭锦旗| 仲巴县| 得荣县| 永兴县| 包头市| 瑞丽市| 雷州市| 乌拉特中旗| 澎湖县| 洪雅县| 靖安县| 福贡县| 柳林县| 滨州市| 沙坪坝区|