国产一区二区精品-国产一区二区精品久-国产一区二区精品久久-国产一区二区精品久久91-免费毛片播放-免费毛片基地

千鋒教育-做有情懷、有良心、有品質的職業教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > MySQL中id通常使用什么數據類型呢?

MySQL中id通常使用什么數據類型呢?

來源:千鋒教育
發布人:xqq
時間: 2023-10-13 02:22:33 1697134953

一、MySQL中id通常使用什么數據類型

一般都是 int 自增設置為主鍵

如果表大的話可以設置為 龍, 或者big int

例如:

‘id’int unsigned not null auto_increment primary key,

1.SQL PRIMARY KEY 約束

PRIMARY KEY 約束少數標識數據庫表中的每條記錄。

主鍵必須包含少數的值。

主鍵列不能包含 NULL 值。

每個表都應該有一個主鍵,并且每個表只能有一個主鍵。

2.AUTO_INCREMENT 字段

我們通常希望在每次插入新記錄時,自動地創建主鍵字段的值。

我們可以在表中創建一個 auto_increment 字段。

3.unsigned 無符號整型

mysql數據庫中unsigned數的操作結果都是unsigned的,select num1 – num2 from table;如果sql_mode不嚴格此時的結果可能是不確定的。sql_mode如果為嚴格模式則此種操作會報越界的異常,解決此問題只需要將參數sql_mode進行如下設置即可:

mysql> set sql_mode=’NO_UNSIGNED_SUBTRACTION’。

延伸閱讀:

二、id的一些典型的類型

整型:整型通常來說是優異的選擇,這是因為整型的運算和比較都很快,而且還可以設置 AUTO_INCREMENT 屬性自動遞增。ENUM 和 SET:通常不會選擇枚舉和集合作為 id,然后對于那些包含有“類型”、“狀態”、“性別”這類型的列來說是挺合適的。例如我們需要有一張表存儲下拉菜單時,通常會有一個值和一個名稱,這個時候值使用枚舉作為主鍵也是可以的。字符串:盡可能地避免使用字符串作為 id,一是字符串占據的空間更大,二是通常會比整型慢。選用字符串作為 id 時,還需要特別注意 MD5、SHA1和 UUID 這些函數。每個值是在很大范圍的隨機值,沒有次序,這會導致插入和查詢更慢:插入的時候,由于建立索引是隨機位置(會導致分頁、隨機磁盤訪問和聚集索引碎片),會降低插入速度。查詢的時候,相鄰的數據行在磁盤或內存上上可能跨度很大,也會導致速度更慢。

如果確實要使用 UUID 值,應當移除掉“-”字符,或者是使用 UNHEX 函數將其轉換為16字節數字,并使用 BINARY(16)存儲。然后可以使用 HEX 函數以十六進制的方式進行獲取。UUID 產生的方法有很多,有些是隨機分布的,有些是有序的,但是即便是有序的性能也不如整型。

聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
10年以上業內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT