最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當(dāng)前位置: 首頁 - 科技 - 知識百科 - 正文

asp.net 產(chǎn)生唯一隨機(jī)碼的方法分析

來源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-27 22:43:00
文檔

asp.net 產(chǎn)生唯一隨機(jī)碼的方法分析

asp.net 產(chǎn)生唯一隨機(jī)碼的方法分析:1. 自己寫代碼產(chǎn)生隨機(jī)的數(shù)字和字母組合,每產(chǎn)生1個(gè)去數(shù)據(jù)庫查詢該隨機(jī)碼是否已存在,如果已存在,則重新產(chǎn)生,直到不重復(fù)為止。 優(yōu)點(diǎn):沒發(fā)現(xiàn)有啥優(yōu)點(diǎn)。 缺點(diǎn):產(chǎn)生速度慢,還要查詢數(shù)據(jù)庫,當(dāng)數(shù)據(jù)量大的時(shí)候,可能重復(fù)的機(jī)率會比較高,要查詢多次數(shù)據(jù)庫.
推薦度:
導(dǎo)讀asp.net 產(chǎn)生唯一隨機(jī)碼的方法分析:1. 自己寫代碼產(chǎn)生隨機(jī)的數(shù)字和字母組合,每產(chǎn)生1個(gè)去數(shù)據(jù)庫查詢該隨機(jī)碼是否已存在,如果已存在,則重新產(chǎn)生,直到不重復(fù)為止。 優(yōu)點(diǎn):沒發(fā)現(xiàn)有啥優(yōu)點(diǎn)。 缺點(diǎn):產(chǎn)生速度慢,還要查詢數(shù)據(jù)庫,當(dāng)數(shù)據(jù)量大的時(shí)候,可能重復(fù)的機(jī)率會比較高,要查詢多次數(shù)據(jù)庫.

1. 自己寫代碼產(chǎn)生隨機(jī)的數(shù)字和字母組合,每產(chǎn)生1個(gè)去數(shù)據(jù)庫查詢該隨機(jī)碼是否已存在,如果已存在,則重新產(chǎn)生,直到不重復(fù)為止。
優(yōu)點(diǎn):沒發(fā)現(xiàn)有啥優(yōu)點(diǎn)。
缺點(diǎn):產(chǎn)生速度慢,還要查詢數(shù)據(jù)庫,當(dāng)數(shù)據(jù)量大的時(shí)候,可能重復(fù)的機(jī)率會比較高,要查詢多次數(shù)據(jù)庫.

2. guid,該方法應(yīng)該是用的比較多的。
  優(yōu)點(diǎn):使用簡單方便,不用自己編寫額外的代碼
  缺點(diǎn):占用數(shù)據(jù)庫空間相對較大,特別是根據(jù)guid查詢速度比較慢(畢竟是字符串)。

3. 主鍵+隨機(jī)碼的方式,我們產(chǎn)生的隨機(jī)碼保存到數(shù)據(jù)庫肯定會有個(gè)主鍵,用該主鍵+隨機(jī)字符來組合。產(chǎn)生步驟:
  1) 先從id生成器中獲取id,比如是155.
  2)填充成固定位數(shù)(比如8位)的字符串(不夠位數(shù)的左邊填0,超過位數(shù)直接使用該數(shù)字),得到:00000155
  3)在每個(gè)數(shù)字后面隨機(jī)插入1個(gè)字母或其它非數(shù)字符號,得到:0A0F0R0Y0H1K5L5M
這樣就可以得到1個(gè)隨機(jī)的唯一的邀請碼了。
  優(yōu)點(diǎn):使用也比較簡單,不用查詢數(shù)據(jù)庫。最大的優(yōu)點(diǎn)是查詢的時(shí)候,可以根據(jù)邀請碼直接得到主鍵id,
    然后根據(jù)id去數(shù)據(jù)庫查詢(速度很快),再比較查詢出來的邀請碼和用戶提交的邀請碼是否一致。
  缺點(diǎn):需要使用id產(chǎn)生器,如果主鍵是數(shù)據(jù)庫自增長的就不太好用(需要先插入數(shù)據(jù)庫獲取id,再更新邀請碼)。

4. 有時(shí)候產(chǎn)品經(jī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)制后就不會出現(xiàn)9這個(gè)字符,然后在后面加個(gè)'9',這樣就能確定唯一性。最后在后面產(chǎn)生一些隨機(jī)數(shù)字就可以。
優(yōu)缺點(diǎn)同方法3

目前方法3,4方法在我們產(chǎn)品中都使用了,感覺還可以。

PS:以上是個(gè)人淺見,有更好方法的同學(xué)請分享下。^_^
[作者]:BearRui(AK-47)
[博客]: http://www.cnblogs.com/BearsTaR/

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

asp.net 產(chǎn)生唯一隨機(jī)碼的方法分析

asp.net 產(chǎn)生唯一隨機(jī)碼的方法分析:1. 自己寫代碼產(chǎn)生隨機(jī)的數(shù)字和字母組合,每產(chǎn)生1個(gè)去數(shù)據(jù)庫查詢該隨機(jī)碼是否已存在,如果已存在,則重新產(chǎn)生,直到不重復(fù)為止。 優(yōu)點(diǎn):沒發(fā)現(xiàn)有啥優(yōu)點(diǎn)。 缺點(diǎn):產(chǎn)生速度慢,還要查詢數(shù)據(jù)庫,當(dāng)數(shù)據(jù)量大的時(shí)候,可能重復(fù)的機(jī)率會比較高,要查詢多次數(shù)據(jù)庫.
推薦度:
標(biāo)簽: 生成 方法 的方式
  • 熱門焦點(diǎn)

最新推薦

猜你喜歡

熱門推薦

專題
Top