|
1. 自己寫代碼產(chǎn)生隨機(jī)的數(shù)字和字母組合,每產(chǎn)生1個(gè)去數(shù)據(jù)庫(kù)查詢?cè)撾S機(jī)碼是否已存在,如果已存在,則重新產(chǎn)生,直到不重復(fù)為止。
優(yōu)點(diǎn):沒發(fā)現(xiàn)有啥優(yōu)點(diǎn)。
缺點(diǎn):產(chǎn)生速度慢,還要查詢數(shù)據(jù)庫(kù),當(dāng)數(shù)據(jù)量大的時(shí)候,可能重復(fù)的機(jī)率會(huì)比較高,要查詢多次數(shù)據(jù)庫(kù).
2. guid,該方法應(yīng)該是用的比較多的。
優(yōu)點(diǎn):使用簡(jiǎn)單方便,不用自己編寫額外的代碼
缺點(diǎn):占用數(shù)據(jù)庫(kù)空間相對(duì)較大,特別是根據(jù)guid查詢速度比較慢(畢竟是字符串)。
3. 主鍵+隨機(jī)碼的方式,我們產(chǎn)生的隨機(jī)碼保存到數(shù)據(jù)庫(kù)肯定會(huì)有個(gè)主鍵,用該主鍵+隨機(jī)字符來(lái)組合。產(chǎn)生步驟:
1) 先從id生成器中獲取id,比如是155.
2)填充成固定位數(shù)(比如8位)的字符串(不夠位數(shù)的左邊填0,超過位數(shù)直接使用該數(shù)字),得到:00000155
3)在每個(gè)數(shù)字后面隨機(jī)插入1個(gè)字母或其它非數(shù)字符號(hào),得到:0A0F0R0Y0H1K5L5M
這樣就可以得到1個(gè)隨機(jī)的唯一的邀請(qǐng)碼了。
優(yōu)點(diǎn):使用也比較簡(jiǎn)單,不用查詢數(shù)據(jù)庫(kù)。最大的優(yōu)點(diǎn)是查詢的時(shí)候,可以根據(jù)邀請(qǐng)碼直接得到主鍵id,然后根據(jù)id去數(shù)據(jù)庫(kù)查詢(速度很快),再比較查詢出來(lái)的邀請(qǐng)碼和用戶提交的邀請(qǐng)碼是否一致。
缺點(diǎn):需要使用id產(chǎn)生器,如果主鍵是數(shù)據(jù)庫(kù)自增長(zhǎng)的就不太好用(需要先插入數(shù)據(jù)庫(kù)獲取id,再更新邀請(qǐng)碼)。
4. 有時(shí)候產(chǎn)品經(jīng)理說(shuō),我要求邀請(qǐng)碼都是數(shù)字的。why?no why? 我喜歡。*(&^(^%&^$&^$ 把方法3變通下就可以實(shí)現(xiàn)唯一的純數(shù)字隨機(jī)碼了。
1) 獲取id: 155
2) 轉(zhuǎn)換成8進(jìn)制:233
3) 轉(zhuǎn)為字符串,并在后面加'9'字符:2339
4)在后面隨機(jī)產(chǎn)生若干個(gè)隨機(jī)數(shù)字字符:2003967524987 轉(zhuǎn)為8進(jìn)制后就不會(huì)出現(xiàn)9這個(gè)字符,然后在后面加個(gè)'9',這樣就能確定唯一性。最后在后面產(chǎn)生一些隨機(jī)數(shù)字就可以。
優(yōu)缺點(diǎn)同方法3
目前方法3,4方法在我們產(chǎn)品中都使用了,感覺還可以。
it知識(shí)庫(kù):產(chǎn)生唯一隨機(jī)碼的方法分析。,轉(zhuǎn)載需保留來(lái)源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。