加入收藏 | 设为首页 | 会员中心 | 我要投稿 PHP编程网 - 湛江站长网 (https://www.0759zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 建站 > 正文

Java技术干货分享:浅谈订单号生成设计方案

发布时间:2019-08-15 21:05:12 所属栏目:建站 来源:IT技术分享
导读:副标题#e# 最简单的方式 基于数据库 auto_increment_increment 来获取 ID。首先在数据库中创建一张 sequence 表,其中 seq_name 用以区分不同业务标识,从而实现支持多种业务场景下的自增 ID, current_value 为当前值, _increment 为步长,可支持分布式数

代码的实现稍微复杂一点,获取 ID 会根据业务标识 sequencename,先从内存获取 Step 的 ID 段,如果为 null,则从数据库中读取当前最新的值,并根据步长计算 Step,然后返回请求 ID。如果从内存中直接获取到 Step,则直接取 ID,并对 currentValue 进行加一。当 currentValue 的值超过 endValue 时,则更新数据库的 ID,重新计算 Step。

  1. private Map<String,Step> stepMap = new HashMap<String, Step>();  
  2. public synchronized long get(String sequenceName) {  
  3. Step step = stepMap.get(sequenceName);  
  4. if(step ==null) {  
  5. step = new Step(startValue,startValue+blockSize);  
  6. stepMap.put(sequenceName, step);  
  7. } else { 
  8. if (step.currentValue < step.endValue) {  
  9. return step.incrementAndGet();  
  10. }  
  11. if (getNextBlock(sequenceName,step)) {  
  12. return step.incrementAndGet();  
  13. }  
  14. throw new RuntimeException("No more value.");  
  15. }  
  16. private boolean getNextBlock(String sequenceName, Step step) {  
  17. // "select id from sequence_value where name = ?";  
  18. Long value = getPersistenceValue(sequenceName);  
  19. if (value == null) { 
  20. try {  
  21. // insert into sequence_value (id,name) values (?,?)  
  22. value = newPersistenceValue(sequenceName);  
  23. } catch (Exception e) {  
  24. value = getPersistenceValue(sequenceName);  
  25. }  
  26. }  
  27. // update sequence_value set id = ? where name = ? and id = ?  
  28. boolean b = saveValue(value,sequenceName) == 1;  
  29. if (b) {  
  30. step.setCurrentValue(value);  
  31. step.setEndValue(value+blockSize); 
  32. }  
  33. return b;  

(编辑:PHP编程网 - 湛江站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!