如何利用数据库和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的高性能和单线程特性,使它在这方面有独特的优势。

O2O建设方案与O2O开发者:共创未来

随着移动互联网和物联网技术的发展,O2O模式已经成为了当前商业领域中的热点。O2O模式即线上到线下,是指通过网络平台将消费者和商家连接起来,实现线上购买、线下体验、线下消费的一种商业模式。而O2O建设方案则是指为了实现O2O模式而制定的具体实施方案,O2O开发者则是指专门为O2O模式开发应用程序、网站等软件的企业或个人。

O2O建设方案

O2O建设方案是指为了实现O2O模式而制定的具体实施方案。一般来说,O2O建设方案需要考虑以下几个方面:

1. 用户需求分析

首先需要对用户的需求进行分析,了解用户的需求是什么,有什么痛点需要解决。只有深入了解用户的需求,才能更好地设计O2O模式,并开发出适合用户的应用程序。

2. 商家合作

接着需要考虑商家合作问题,如何让商家愿意接入O2O模式,并提供相应的服务。这需要对商家进行调研,了解商家的发展需求,并提供相应的解决方案。

3. 平台搭建

然后需要考虑平台搭建问题,如何开发O2O平台,并提供相应的服务。这需要考虑技术实现、用户体验、支付安全等方面的问题。

4. 服务设计

接下来需要对服务进行设计,包括服务的提供、购买方式、支付方式等方面。服务的设计需要考虑用户体验,确保用户可以方便快捷地完成购买服务、查看服务详情、进行支付等操作。

5. 营销推广

最后需要进行营销推广,吸引更多的用户使用O2O模式,并提供更多的优惠活动,促进用户消费。

O2O开发者

O2O开发者则是指专门为O2O模式开发应用程序、网站等软件的企业或个人。O2O开发者需要从技术、市场、用户体验等多个方面来考虑O2O模式的发展,以帮助O2O模式更好地实现O2O建设方案。

1. 技术支持

O2O开发者需要为O2O模式提供技术支持,包括开发O2O平台、支持多样支付方式、设计服务体验等。

2. 市场推广

O2O开发者需要为O2O模式进行市场推广,包括设计吸引用户的界面、编写有吸引力的服务描述、为O2O模式提供丰富的服务和优惠等,以吸引更多的用户使用O2O模式。

3. 用户体验设计

O2O开发者需要从用户的角度出发,设计用户友好的界面、提供良好的用户体验、实现便捷的服务购买方式等,以满足用户的需求,提升用户满意度。

4. 服务设计

O2O开发者需要根据O2O模式的需求设计服务,包括设计服务流程、提供详细的服务信息、实现多样化的支付方式等,以提升服务质量,满足用户需求。

共创未来

O2O建设方案与O2O开发者是实现O2O模式的重要力量,只有O2O建设方案协同O2O开发者,才能实现O2O模式共创未来。