如何利用数据库和Redis为每个系统开发独立的自增ID生成器 DROPTABLEIFEXISTSsys_id_re / 如何利用数据库和Redis为每个系统开发独立的自增ID生成器 DROPTABLEIFEXISTSsys_id_re

这个设计的核心思想是数据库控制各个子系统的起始值和步长,然后将值放到redis队列中,从队列中依此取值。当从redis中消耗掉后再次从数据库中取一批值,依此循环。

总结
package com.davidwang456.test;  import java.util.ArrayList; import java.util.List;  import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.redis.core.RedisTemplate; import org.springframework.stereotype.Service;  @Service public class IDGenerateServiceImpl implements IDGenerateService {    @Autowired    private SysIdRecordDao sysIdRecordDao;        @Autowired    private RedisTemplate redisTemplate;      @Override     public String getIDGenerateBySys(String sysId) {         init(sysId);         Object idSys=redisTemplate.opsForList().rightPop(sysId);         if(idSys==null) {             List records=sysIdRecordDao.getEnabledSysIdRecord(sysId);             if(records!=null&&records.isEmpty()) {                 SysIdRecord record=records.get(0);                                  List buf_ids=new ArrayList();                 for(int i=1;i<record.getLenth+1;i++) {                     buf_ids.add(record.getIdFrom+i);                 }                 redisTemplate.opsForList().leftPushAll(sysId, buf_ids);                 record.setIdFrom(record.getIdFrom()+record.getLenth());                 sysIdRecordDao.save(record);                 idSys=redisTemplate.opsForList().rightPop(sysId);             }         }         return sysId+":"+idSys;     }          private void init(String sysId) {         if(!redisTemplate.hasKey(sysId)) {             List records=sysIdRecordDao.getEnabledSysIdRecord(sysId);             if(records==null||records.isEmpty()) {                 SysIdRecord record=new SysIdRecord();                 //TODO                 sysIdRecordDao.save(record);             }         }      }  } 
接口服务实现
package com.davidwang456.test;   public interface IDGenerateService {   String getIDGenerateBySys(String sysId); }
定义服务接口
主要代码
DROP TABLE IF EXISTS sys_id_record; CREATE TABLE sys_id_record( id INT UNSIGNED AUTO_INCREMENT, sys_id VARCHAR(40) NOT NULL COMMENT '子系统ID', sys_name VARCHAR(100) NOT NULL COMMENT '子系统名称', id_from INT NOT NULL DEFAULT 1 COMMENT '子系统ID起始值', lenth SMALLINT NOT NULL DEFAULT 10 COMMENT '子系统ID长度', enabled VARCHAR(1) NOT NULL DEFAULT 'Y', created_by VARCHAR(40) NOT NULL COMMENT '创建人', created_date DATETIME COMMENT '创建时间', updated_by VARCHAR(40) NOT NULL COMMENT '更新人', updated_date DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间', PRIMARY KEY ( id ) )ENGINE=INNODB DEFAULT CHARSET=utf8; 
数据库设计(mysql)
各系统独立的自增ID生成器

为了解决各个系统独自生成自增的唯一ID的需求,而又实现简单有效,做了如下设计。

而因为Redis的高性能和单线程特性,使它在这方面有独特的优势。

JavaScript是一门广泛使用的编程语言,可以在网站和应用程序中添加交互性和动态性。它被用于开发各种类型的应用程序,包括桌面应用程序、Web应用程序、移动应用程序等。JavaScript不仅是一门流行的编程语言,而且学习它还有许多好处。

首先,学习JavaScript可以帮助您开发更好的网站和应用程序。JavaScript可以用来制作交互式的用户界面和动画效果,这使得网站和应用程序更具吸引力和易用性。使用JavaScript还可以帮助您优化网站和应用程序的性能,使它们更快、更稳定。

其次,学习JavaScript可以增加您的职业发展机会。许多公司和组织正在寻找熟练的JavaScript开发人员,他们可以为企业开发Web应用程序、移动应用程序、桌面应用程序等。学习JavaScript还可以使您更具竞争力,因为它是一种广泛使用的编程语言。

此外,学习JavaScript还可以提高您的编程技能。JavaScript是一种灵活的语言,可以用于许多不同的应用程序和场景。学习JavaScript可以帮助您理解面向对象编程、函数式编程、异步编程等编程概念。这些概念在其他编程语言中也很有用。

最后,学习JavaScript可以增加您的创造力。JavaScript是一种有趣的语言,可以用来解决各种问题。学习JavaScript可以帮助您想出新的想法和解决方案。这种创造力不仅可以用于编程领域,还可以用于其他领域。

总之,学习JavaScript是一种值得的投资。它可以帮助您开发更好的网站和应用程序,增加职业发展机会,提高编程技能和增加创造力。如果您正在考虑学习编程,那么学习JavaScript将是一个很好的开始。