java javaWeb 在系統(tǒng)高并發(fā)的情況下生成有序流水號(hào)?
javaWeb 在系統(tǒng)高并發(fā)的情況下生成有序流水號(hào)?1. 如果主題不要求ID是數(shù)字,建議使用最簡(jiǎn)單的一個(gè),即UUID,它包含機(jī)器代碼、時(shí)間戳、隨機(jī)數(shù)等,但UUID最終生成一個(gè)全局唯一的字符串,而不是整
javaWeb 在系統(tǒng)高并發(fā)的情況下生成有序流水號(hào)?
1. 如果主題不要求ID是數(shù)字,建議使用最簡(jiǎn)單的一個(gè),即UUID,它包含機(jī)器代碼、時(shí)間戳、隨機(jī)數(shù)等,但UUID最終生成一個(gè)全局唯一的字符串,而不是整數(shù),并且看起來順序不對(duì)。
2. MySQL自己添加ID。它使用一個(gè)表來存儲(chǔ)各種業(yè)務(wù)id。每個(gè)分布式系統(tǒng)插入一個(gè)ID后,生成1000萬個(gè)本地號(hào)碼與ID拼接,然后每個(gè)系統(tǒng)得到一個(gè)ID,相當(dāng)于生成1000萬個(gè)ID,足夠長(zhǎng)時(shí)間使用。這1000萬個(gè)ID可以預(yù)先定義,并在系統(tǒng)啟動(dòng)時(shí)放入內(nèi)存。因?yàn)樗鼈冎皇荌D,所以不會(huì)占用太多內(nèi)存。MySQL可以內(nèi)置到集群中,這不會(huì)影響自增IDs的使用。
3. 與MySQL的auto-increment ID類似,redis的incr實(shí)現(xiàn)了自動(dòng)增量。每個(gè)分布式系統(tǒng),比如redis,都是用incr插入一個(gè)ID,然后生成1000萬個(gè)本地號(hào)碼與ID拼接,如果每個(gè)系統(tǒng)都有一個(gè)ID,相當(dāng)于生成1000萬個(gè)ID,足夠長(zhǎng)時(shí)間使用。這1000萬個(gè)ID可以預(yù)先定義,并在系統(tǒng)啟動(dòng)時(shí)放入內(nèi)存。因?yàn)樗皇且粋€(gè)ID,所以不會(huì)占用太多內(nèi)存。Redis也可以內(nèi)置到集群中,這不會(huì)影響自增ID的使用。Twitter的雪花算法與UUID類似,包括機(jī)器碼、時(shí)間戳、隨機(jī)數(shù)等,但最終生成的是64位整數(shù),可以滿足許多分布式系統(tǒng)的要求。如果Id必須是整數(shù),建議使用snowflake而不是UUID。
Java程序連接Oracle數(shù)據(jù)庫時(shí)怎么設(shè)置主鍵自增?
在Oracle中,主鍵不是自遞增的,但您可以創(chuàng)建一個(gè)序列--創(chuàng)建序列創(chuàng)建序列seq Text minValue 1 maxvalue 9999 start with 60 increment by 1 cache 20 insert into student(ID,name)values(seq u文本.NEXTVAL“,”張三“)這沒關(guān)系
在mysql中,是這樣的:例如,您剛剛插入了一條語句:String SQL=“insert into table values(…)”objConn.executeUpdate對(duì)象(SQL)下面是剛剛插入數(shù)據(jù)庫的ID號(hào)long RETuID=0ResultSet rs=對(duì)象執(zhí)行(“select LAST INSERT ID()”)如果(下一個(gè)())返回id=蓋特朗盧比(1) 首先,你得有張桌子!Create table example(IDnumber(4)not number primary key,name varchar(25),phone varchar(10),address varchar(50))如果您對(duì)上述建表語句有任何疑問,建議您不要繼續(xù)!如果有時(shí)間,不妨去看看金庸,讀瓊瑤!然后,需要一個(gè)自定義的sequencecreatesequenceemp Sequence incrementby1—一次添加幾個(gè)starthith1—從1開始計(jì)數(shù),nomaxvalue—不設(shè)置最大值,nocycle—一直累積,不循環(huán),nocache—不構(gòu)建緩沖區(qū)。上面的代碼完成了創(chuàng)建一個(gè)序列的過程,名為EMP_uu序列,范圍從1到無窮大(無窮大的程度由您的機(jī)器決定)。不騎自行車就是決定不騎自行車。如果設(shè)置最大值,可以使用cycle將SEQ設(shè)置為最大值,然后循環(huán)。