1. 本身寫代碼產生隨機的數字和字母組合,每產生1個去數據庫查詢該隨機碼是否已存在,若是已存在,則從新產生,直到不重複爲止。html
優勢:沒發現有啥優勢。 java
缺點:產生速度慢,還要查詢數據庫,當數據量大的時候,可能重複的機率會比較高,要查詢屢次數據庫.python
2. guid,該方法應該是用的比較多的。 git
優勢:使用簡單方便,不用本身編寫額外的代碼 數據庫
缺點:佔用數據庫空間相對較大,特別是根據guid查詢速度比較慢(畢竟是字符串)。dom
3. 主鍵+隨機碼的方式,咱們產生的隨機碼保存到數據庫確定會有個主鍵,用該主鍵+隨機字符來組合。產生步驟: 函數
1) 先從id生成器中獲取id,好比是155. post
2)填充成固定位數(好比8位)的字符串(不夠位數的左邊填0,超過位數直接使用該數字),獲得:00000155 ui
3)在每一個數字後面隨機插入1個字母或其它非數字符號,獲得:0A0F0R0Y0H1K5L5Mspa
這樣就能夠獲得1個隨機的惟一的邀請碼了。
優勢:使用也比較簡單,不用查詢數據庫。最大的優勢是查詢的時候,能夠根據邀請碼直接獲得主鍵id,
而後根據id去數據庫查詢(速度很快),再比較查詢出來的邀請碼和用戶提交的邀請碼是否一致。
缺點:須要使用id產生器,若是主鍵是數據庫自增加的就不太好用(須要先插入數據庫獲取id,再更新邀請碼)。
4. 有時候產品經理說,我要求邀請碼都是數字的。why?no why? 我喜歡。*(&^(^%&^$&^$ 把方法3變通下就能夠實現惟一的純數字隨機碼了。
1) 獲取id: 155
2) 轉換成8進制:233
3) 轉爲字符串,並在後面加'9'字符:2339
4)在後面隨機產生若干個隨機數字字符:2003967524987
轉爲8進制後就不會出現9這個字符,而後在後面加個'9',這樣就能肯定惟一性。最後在後面產生一些隨機數字就能夠。
優缺點同方法3
一個栗子:
作爲 Apple Store App 獨立開發者,你要搞限時促銷,爲你的應用生成激活碼(或者優惠券),使用 Python 如何生成 200 個激活碼(或者優惠券)?
其實要生成激活碼(邀請碼)也是很簡單的事, 好比隨機生成.或者使用GUID,UUID等,很是簡單
可是咱們得考慮存入以及驗證的問題.
參考產生惟一隨機碼的方法分析。這篇文章的思路:
主鍵+隨機碼的方式.
這種方法優勢:使用也比較簡單,不用直接去查詢數據庫,而最大的優勢是查詢的時候,能夠根據邀請碼直接獲得主鍵id, 而後根據id去數據庫查詢(速度很快),再比較查詢出來的邀請碼和用戶提交的邀請碼是否一致。
#!/usr/bin/env python # -*- coding: utf-8 -*- import random import string def activation_code(id,length=10): ''' id + L + 隨機碼 string模塊中的3個函數:string.letters,string.printable,string.printable ''' prefix = hex(int(id))[2:]+ 'L' length = length - len(prefix) chars=string.ascii_letters+string.digits return prefix + ''.join([random.choice(chars) for i in range(length)]) def get_id(code): ''' Hex to Dec ''' return str(int(code.upper(), 16)) if __name__=="__main__": for i in range(10,500,35): code = activation_code(i) id_hex = code.split('L')[0] id = get_id(id_hex) print code,id
運行結果:
aLp5EzM4D2 10 2dL8TuFB2o 45 50LklqcpNp 80 73La8yOuo1 115 96LavIm2bS 150 b9LZd4PV3D 185 dcL05As00w 220 ffLeD0sy3C 255 122Lgi6YGs 290 145Ljin1B5 325 168L1k7ypr 360 18bL1RYoIE 395 1aeLaMAKrT 430 1d1LHbYL7X 465