簡體   English   中英

自動遞增PK的備用字段

[英]Alternate field for autoincrement PK

在我的表格中,我在存儲文章和評論的表格上使用自動遞增PK。
我不想將PK公開給HTTP客戶端,但是,我仍然在API實現中內部使用它來執行快速查找。

當用戶想要按ID檢索帖子時,我希望在表上有一個備用的唯一鍵。 我想知道什么是最好的(最常見的)方式用作此字段的類型。
對我而言,最明顯的是使用UUID或GUID。
我想知道是否有一種直接的方法來為此生成隨機數字鍵,而不是為了提高性能。

您對這種情況采取的最佳方法是什么?

MySQL具有生成功能的功能,如RFC 4122中所述,該功能可生成128位UUID版本1,並通過UUID格式的自定義將其作為帶短划線的十六進制字符串返回。

https://dev.mysql.com/doc/refman/5.7/zh-CN/miscellaneous-functions.html#function_uuid

真正的UUID意味着在時間和空間上是全球唯一的。 通常,除非您需要一組分布式的獨立服務器來生成唯一值而無需進行某些中央唯一性驗證(這可能會造成瓶頸),否則這是過大的。

MySQL還具有一個UUID_SHORT()函數,該函數生成64位數字值。 這不符合RFC,但對您的情況可能有用。

https://dev.mysql.com/doc/refman/5.7/zh-CN/miscellaneous-functions.html#function_uuid-short

閱讀有關UUID_SHORT()實現的描述。 由於高位很少更改,而低位只是單調遞增,因此避免了由於將隨機UUID值插入索引而導致的性能和碎片問題。

UUID_SHORT值也適合MySQL BIGINT UNSIGNED而不必使用UNHEX()

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM