每次需要生成n
個1~s
之間的隨機整數(shù)
,并存入數(shù)據(jù)庫,生成的隨機數(shù)不能與數(shù)據(jù)庫已有的數(shù)據(jù)重復
由于數(shù)據(jù)量達百萬級別,并且操作執(zhí)行頻率高,思路1的方法消耗性能資源太大,思路2又由于執(zhí)行時間不可期,更不可取。
對于這種需求,是否有更合理的處理方式?
寫一個我的思路,采用減法
我覺得你的s應該是一個固定的數(shù)吧,既然這樣那么能出現(xiàn)的所有數(shù)據(jù)也已經(jīng)固定下來了
比如s=1000000,那么1~1000000里的隨機整數(shù)的全部可能也固定下來了
那么現(xiàn)在數(shù)據(jù)庫里創(chuàng)1000000條數(shù)據(jù),然后用戶來拿一個數(shù)了,就全部取出來,然后隨機一個整數(shù)出來,把這個數(shù)返給用戶的同時給這個數(shù)在數(shù)據(jù)庫里設置一個字段,比如used:true
下次用戶來取的時候再從數(shù)據(jù)庫里取全部數(shù),不過要帶上篩選條件,used不為true的,把取出的集合再隨機一個數(shù)出來分配給用戶,再把隨機出來的數(shù)在數(shù)據(jù)庫里設置一個相同字段,比如used:true
以此類推
這樣應該不會存在重復的問題,開銷的話也只是查一次數(shù)據(jù)庫而已,比你的1,2應該都快
當然這個還有優(yōu)化的空間,比如這個所有的數(shù)據(jù)也不一定存在數(shù)據(jù)庫里啊,redis應該也更快,等等。我只是說下我的思路
北大青鳥APTECH成立于1999年。依托北京大學優(yōu)質雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國家
北大青鳥中博軟件學院創(chuàng)立于2003年,作為華東區(qū)著名互聯(lián)網(wǎng)學院和江蘇省首批服務外包人才培訓基地,中博成功培育了近30000名軟件工程師走向高薪崗位,合作企業(yè)超4
中公教育集團創(chuàng)建于1999年,經(jīng)過二十年潛心發(fā)展,已由一家北大畢業(yè)生自主創(chuàng)業(yè)的信息技術與教育服務機構,發(fā)展為教育服務業(yè)的綜合性企業(yè)集團,成為集合面授教學培訓、網(wǎng)
達內教育集團成立于2002年,是一家由留學海歸創(chuàng)辦的高端職業(yè)教育培訓機構,是中國一站式人才培養(yǎng)平臺、一站式人才輸送平臺。2014年4月3日在美國成功上市,融資1
曾工作于聯(lián)想擔任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔任項目經(jīng)理從事移動互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍懿科技有限責任公司從事總經(jīng)理職務負責iOS教學及管理工作。
浪潮集團項目經(jīng)理。精通Java與.NET 技術, 熟練的跨平臺面向對象開發(fā)經(jīng)驗,技術功底深厚。 授課風格 授課風格清新自然、條理清晰、主次分明、重點難點突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應用開發(fā)經(jīng)驗。曾經(jīng)歷任德國Software AG 技術顧問,美國Dachieve 系統(tǒng)架構師,美國AngelEngineers Inc. 系統(tǒng)架構師。