1. 本身寫代碼產生隨機的數字和字母組合,每產生1個去數據庫查詢該隨機碼是否已存在,若是已存在,則從新產生,直到不重複爲止。 數據庫
優勢:沒發現有啥優勢。 ui
缺點:產生速度慢,還要查詢數據庫,當數據量大的時候,可能重複的機率會比較高,要查詢屢次數據庫. 字符串
2. guid,該方法應該是用的比較多的。 產品
優勢:使用簡單方便,不用本身編寫額外的代碼 gui
缺點:佔用數據庫空間相對較大,特別是根據guid查詢速度比較慢(畢竟是字符串)。 隨機數
3. 主鍵+隨機碼的方式,咱們產生的隨機碼保存到數據庫確定會有個主鍵,用該主鍵+隨機字符來組合。產生步驟: 方法
1) 先從id生成器中獲取id,好比是155. 數據
2)填充成固定位數(好比8位)的字符串(不夠位數的左邊填0,超過位數直接使用該數字),獲得:00000155 查詢
3)在每一個數字後面隨機插入1個字母或其它非數字符號,獲得:0A0F0R0Y0H1K5L5M 生成器
這樣就能夠獲得1個隨機的惟一的邀請碼了。
優勢:使用也比較簡單,不用查詢數據庫。最大的優勢是查詢的時候,能夠根據邀請碼直接獲得主鍵id,而後根據id去數據庫查詢(速度很快),再比較查詢出來的邀請碼和用戶提交的邀請碼是否一致。
缺點:須要使用id產生器,若是主鍵是數據庫自增加的就不太好用(須要先插入數據庫獲取id,再更新邀請碼)。
4. 有時候產品經理說,我要求邀請碼都是數字的。把方法3變通下就能夠實現惟一的純數字隨機碼了。
1) 獲取id: 155
2) 轉換成8進制:233
3) 轉爲字符串,並在後面加'9'字符:2339
4)在後面隨機產生若干個隨機數字字符:2003967524987
轉爲8進制後就不會出現9這個字符,而後在後面加個'9',這樣就能肯定惟一性。最後在後面產生一些隨機數字就能夠。
優缺點同方法3