日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

mybatis - Java關于Mysql的隨機id生成

瀏覽:225日期:2022-06-13 11:54:26

問題描述

正在做一個電商項目,在生成id的時候遇到了一點問題。直接采用mysql的auto_increment肯定是不行的,因為這樣的話生成訂單不太安全,第三方可以直接通過id來監控某個時候生成的訂單數。請問類似segmentfault和簡書等網站,我注意到它們生成文章的id一般都比較隨機,為了考慮查找效率肯定不是通過隨機數。請問生成訂單id我應該采取什么方式?

問題解答

回答1:

考慮snowflake算法嗎?

回答2:

幫你搜到一個

/** * Twitter_Snowflake<br> * SnowFlake的結構如下(每部分用-分開):<br> * 0 - 0000000000 0000000000 0000000000 0000000000 0 - 00000 - 00000 - 000000000000 <br> * 1位標識,由于long基本類型在Java中是帶符號的,最高位是符號位,正數是0,負數是1,所以id一般是正數,最高位是0<br> * 41位時間截(毫秒級),注意,41位時間截不是存儲當前時間的時間截,而是存儲時間截的差值(當前時間截 - 開始時間截) * 得到的值),這里的的開始時間截,一般是我們的id生成器開始使用的時間,由我們程序來指定的(如下下面程序IdWorker類的startTime屬性)。41位的時間截,可以使用69年,年T = (1L << 41) / (1000L * 60 * 60 * 24 * 365) = 69<br> * 10位的數據機器位,可以部署在1024個節點,包括5位datacenterId和5位workerId<br> * 12位序列,毫秒內的計數,12位的計數順序號支持每個節點每毫秒(同一機器,同一時間截)產生4096個ID序號<br> * 加起來剛好64位,為一個Long型。<br> * SnowFlake的優點是,整體上按照時間自增排序,并且整個分布式系統內不會產生ID碰撞(由數據中心ID和機器ID作區分),并且效率較高,經測試,SnowFlake每秒能夠產生26萬ID左右。 */public class SnowflakeIdWorker { // ==============================Fields=========================================== /** 開始時間截 (2015-01-01) */ private final long twepoch = 1420041600000L; /** 機器id所占的位數 */ private final long workerIdBits = 5L; /** 數據標識id所占的位數 */ private final long datacenterIdBits = 5L; /** 支持的最大機器id,結果是31 (這個移位算法可以很快的計算出幾位二進制數所能表示的最大十進制數) */ private final long maxWorkerId = -1L ^ (-1L << workerIdBits); /** 支持的最大數據標識id,結果是31 */ private final long maxDatacenterId = -1L ^ (-1L << datacenterIdBits); /** 序列在id中占的位數 */ private final long sequenceBits = 12L; /** 機器ID向左移12位 */ private final long workerIdShift = sequenceBits; /** 數據標識id向左移17位(12+5) */ private final long datacenterIdShift = sequenceBits + workerIdBits; /** 時間截向左移22位(5+5+12) */ private final long timestampLeftShift = sequenceBits + workerIdBits + datacenterIdBits; /** 生成序列的掩碼,這里為4095 (0b111111111111=0xfff=4095) */ private final long sequenceMask = -1L ^ (-1L << sequenceBits); /** 工作機器ID(0~31) */ private long workerId; /** 數據中心ID(0~31) */ private long datacenterId; /** 毫秒內序列(0~4095) */ private long sequence = 0L; /** 上次生成ID的時間截 */ private long lastTimestamp = -1L; //==============================Constructors===================================== /** * 構造函數 * @param workerId 工作ID (0~31) * @param datacenterId 數據中心ID (0~31) */ public SnowflakeIdWorker(long workerId, long datacenterId) {if (workerId > maxWorkerId || workerId < 0) { throw new IllegalArgumentException(String.format('worker Id can’t be greater than %d or less than 0', maxWorkerId));}if (datacenterId > maxDatacenterId || datacenterId < 0) { throw new IllegalArgumentException(String.format('datacenter Id can’t be greater than %d or less than 0', maxDatacenterId));}this.workerId = workerId;this.datacenterId = datacenterId; } // ==============================Methods========================================== /** * 獲得下一個ID (該方法是線程安全的) * @return SnowflakeId */ public synchronized long nextId() {long timestamp = timeGen();//如果當前時間小于上一次ID生成的時間戳,說明系統時鐘回退過這個時候應當拋出異常if (timestamp < lastTimestamp) { throw new RuntimeException( String.format('Clock moved backwards. Refusing to generate id for %d milliseconds', lastTimestamp - timestamp));}//如果是同一時間生成的,則進行毫秒內序列if (lastTimestamp == timestamp) { sequence = (sequence + 1) & sequenceMask; //毫秒內序列溢出 if (sequence == 0) {//阻塞到下一個毫秒,獲得新的時間戳timestamp = tilNextMillis(lastTimestamp); }}//時間戳改變,毫秒內序列重置else { sequence = 0L;}//上次生成ID的時間截lastTimestamp = timestamp;//移位并通過或運算拼到一起組成64位的IDreturn ((timestamp - twepoch) << timestampLeftShift) //| (datacenterId << datacenterIdShift) //| (workerId << workerIdShift) //| sequence; } /** * 阻塞到下一個毫秒,直到獲得新的時間戳 * @param lastTimestamp 上次生成ID的時間截 * @return 當前時間戳 */ protected long tilNextMillis(long lastTimestamp) {long timestamp = timeGen();while (timestamp <= lastTimestamp) { timestamp = timeGen();}return timestamp; } /** * 返回以毫秒為單位的當前時間 * @return 當前時間(毫秒) */ protected long timeGen() {return System.currentTimeMillis(); } //==============================Test============================================= /** 測試 */ public static void main(String[] args) {SnowflakeIdWorker idWorker = new SnowflakeIdWorker(0, 0);for (int i = 0; i < 1000; i++) { long id = idWorker.nextId(); System.out.println(Long.toBinaryString(id)); System.out.println(id);} }}

文章鏈接 http://www.cnblogs.com/reluce...

回答3:

使用 mysql 內置函數: UUID(),生成不重復的 id;另外設置流水號字段,使用自增。

相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
美女久久久久| 欧美日韩精品免费观看视欧美高清免费大片 | 国产一区二区精品| 国产美女高潮在线| 欧美少妇精品| 91精品婷婷色在线观看| 国产激情欧美| 亚洲不卡av不卡一区二区| 久久久亚洲欧洲日产| 久久久久观看| 亚洲91视频| 亚洲丝袜啪啪| 美女视频黄免费的久久| 国产va在线视频| 2023国产精品久久久精品双| 狠狠爱www人成狠狠爱综合网| 中文日韩欧美| 91福利精品在线观看| 亚洲影视一区二区三区| 国产人成精品一区二区三| 国内精品美女在线观看| 亚洲播播91| 在线观看视频免费一区二区三区| 欧美日韩18| 国产精品久久久亚洲一区| 日本免费久久| 日韩国产在线一| 亚洲伦乱视频| 91精品视频一区二区| 日韩88av| 日韩av二区在线播放| 色偷偷偷在线视频播放| 亚洲精品自拍| 久久蜜桃资源一区二区老牛| 青草综合视频| 亚洲美洲欧洲综合国产一区| 日本欧美在线| 色婷婷久久久| 国产激情精品一区二区三区| 巨乳诱惑日韩免费av| 午夜视频精品| 精品一区二区三区的国产在线观看| 91精品啪在线观看国产18| 欧美精品1区| 日韩高清一区在线| 在线亚洲欧美| 在线成人直播| 亚洲成av在线| 国产 日韩 欧美 综合 一区| 日本免费新一区视频| 久久福利一区| 久久免费大视频| 精品国产成人| 精品91福利视频| 国产精品一区二区av日韩在线| 99成人在线视频| 国产在线观看www| 欧美在线91| 在线日韩欧美| 99精品视频在线观看免费播放| 风间由美中文字幕在线看视频国产欧美| 亚洲精品欧洲| 三级欧美韩日大片在线看| 国产亚洲永久域名| 99国内精品| 一区二区高清| 国产视频一区二| 亚洲精品婷婷| 国产日韩中文在线中文字幕| 欧美日韩午夜电影网| 久久国产精品色av免费看| 日本亚洲最大的色成网站www | 精品国产a一区二区三区v免费| 日韩高清三区| 日韩精品五月天| 国产精品亚洲欧美日韩一区在线| 偷拍亚洲精品| 国产调教一区二区三区| 久久一区亚洲| 欧美日韩国产在线一区| 亚洲一区欧美| 国产欧美视频在线| 色乱码一区二区三区网站| xxxxx性欧美特大| 亚洲欧美不卡| 视频一区中文字幕精品| 91麻豆精品激情在线观看最新| 欧美欧美黄在线二区| 国产一区二区三区精品在线观看| 成人在线网站| 夜久久久久久| 伊人精品在线| 亚洲精品无播放器在线播放| 久久av中文| 久热综合在线亚洲精品| 麻豆国产精品视频| 国产亚洲福利| 国产精品99视频| 亚洲精选av| 久久久久蜜桃| 麻豆成人在线观看| 中文一区一区三区免费在线观 | 亚洲精品888| 国产精品777777在线播放 | 国产欧美日韩精品高清二区综合区| 精品99久久| 日韩精品欧美精品| 久久三级视频| 久久久久亚洲精品中文字幕| 免费成人在线视频观看| 欧美片第1页| 黄色欧美在线| 欧美成人aaa| 美美哒免费高清在线观看视频一区二区| 麻豆国产欧美日韩综合精品二区| 亚洲欧美高清| 婷婷亚洲综合| 久久蜜桃资源一区二区老牛| 久久91视频| 国产精品调教| 久久国际精品| 欧美一区91| 啪啪国产精品| 日本欧美国产| 狠狠久久伊人| 国产成人精品999在线观看| 国产毛片久久久| 国产欧美自拍| 欧美一区二区三区免费看| 一区二区国产在线观看| 日产欧产美韩系列久久99| 亚洲制服欧美另类| 日韩精品导航| 国产精品网址| 国产成人黄色| 亚洲欧美伊人| 男女精品网站| 日本不卡视频在线观看| 国产欧美日韩精品一区二区三区 | 国产精品a久久久久| 蜜桃久久av一区| 日韩高清中文字幕一区二区| 激情亚洲影院在线观看| 99精品网站| 亚洲在线免费| 国产亚洲精品美女久久| 国产精选在线| 亚洲深爱激情| 国产精品porn| 欧美福利在线| 国产午夜久久av| 日韩大片在线| 蜜臀av性久久久久蜜臀aⅴ流畅 | av中文资源在线资源免费观看| 久久精品123| 综合视频一区| 丝袜国产日韩另类美女| 在线亚洲观看| 麻豆精品久久| 久久久久国产精品一区三寸| 日韩一区精品视频| 精品视频一二| 影音先锋久久精品| 日本欧美不卡| 国产精品尤物| 久久免费高清| 国产精品激情| 亚洲欧美日韩视频二区| 欧美激情综合| 亚洲精品日韩久久| 日韩在线观看一区| 麻豆传媒一区二区三区| 另类激情亚洲| 激情综合在线| 成人va天堂| 丁香婷婷久久| 欧美日本不卡| 中文字幕一区二区三区在线视频| 午夜在线视频一区二区区别| 日韩av一区二区三区四区| 国产精品亚洲一区二区三区在线观看| 丝袜美腿高跟呻吟高潮一区| 国产成人精品一区二区三区免费| 亚洲精品精选| 国产毛片一区| 亚洲一级网站| 激情自拍一区| 91精品一区二区三区综合在线爱| 国产精久久一区二区| 97成人超碰| 国产精品成人3p一区二区三区| 91欧美精品| 欧美激情 亚洲a∨综合| 久久wwww| 久久精品网址| 国产精品一区高清| 欧美午夜网站| 粉嫩av一区二区三区四区五区 | 91成人福利| 久久国产婷婷国产香蕉|