zoukankan      html  css  js  c++  java
  • java中生成流水号的一个例子(使用BerkeleyDB)

    package com.jiaoyiping.berkeleydb;
    
    import com.sleepycat.je.*;
    import com.sleepycat.utilint.StringUtils;
    import org.slf4j.Logger;
    import org.slf4j.LoggerFactory;
    
    import java.io.UnsupportedEncodingException;
    
    /**
     * Created with IntelliJ IDEA.
     * User: 焦一平
     * Date: 14-7-9
     * Time: 下午1:27
     * To change this template use File | Settings | File Templates.
     * 1.直接存key和value
     * 2.存储key和value组合成的对象(未使用)
     */
    public class SerialNumberGenerator {
        Logger logger = LoggerFactory.getLogger(SerialNumberGenerator.class);
        private static int MAX_VALUE = 9999;
        private static int MIN_VALUE = 1;
    
        /**
         * 对于任何的请求,总是先取出当前的值返回,然后再将数据库里的值加一
         * @param key 业务主键
         * @return 当前值
         */
        public String getNextValue(String key){
            String currentValue = this.readCurrentValueFromDatabase(key);
            String result;
            if (currentValue == null || "".equals(currentValue)){
                result = this.formatString(MIN_VALUE);
                this.instrtIntoDataBase(key,(MIN_VALUE+1)+"");
                BerkeleyDBUtil.getDatabase().getEnvironment().sync();
    
            }
            else{
                int intCurrentValue = Integer.parseInt(currentValue);
                result = this.formatString(intCurrentValue);
    
                //存储下一个值
                String nextValue = "";
                if (intCurrentValue == MAX_VALUE){
                    nextValue = MIN_VALUE+"";
                }else {
                    nextValue = (intCurrentValue+1) +"";
                }
                this.instrtIntoDataBase(key,nextValue);
                BerkeleyDBUtil.getDatabase().getEnvironment().sync();
    
            }
    
            return result;
        }
        public String readCurrentValueFromDatabase(String key){
            DatabaseEntry theKey = new DatabaseEntry(StringUtils.toUTF8(key));
            DatabaseEntry theValue = new DatabaseEntry();
            TransactionConfig txnConfig = new TransactionConfig();
            txnConfig.setSerializableIsolationVoid(true);
            Database database = BerkeleyDBUtil.getDatabase();
            //Transaction txn = database.getEnvironment().beginTransaction(null,txnConfig);
            OperationStatus status = database.get(null,theKey,theValue,LockMode.DEFAULT);
            //对应的键不存在
            if (status == OperationStatus.KEYEMPTY){
                return null;
            }
            else if (status == OperationStatus.SUCCESS){
                byte[] data = theValue.getData();
                String result;
                try {
                    result = new String(data,"UTF-8");
                } catch (UnsupportedEncodingException e) {
                    e.printStackTrace();  //To change body of catch statement use File | Settings | File Templates.
                    result = "";
                }
                return result;
            }
    
    
            return null;
        }
    
        public void instrtIntoDataBase(String key,String value){
            DatabaseEntry theKey = new DatabaseEntry(StringUtils.toUTF8(key));
            DatabaseEntry theValue = new DatabaseEntry(StringUtils.toUTF8(value));
            TransactionConfig txnConfig = new TransactionConfig();
            txnConfig.setSerializableIsolationVoid(true);
            Database database = BerkeleyDBUtil.getDatabase();
            //Transaction txn = database.getEnvironment().beginTransaction(null,txnConfig);
            OperationStatus status = database.put(null,theKey,theValue);
            if (status == OperationStatus.SUCCESS){
                logger.info("保存成功");
            }
    //        else if (status == OperationStatus.KEYEXIST){
    //            logger.info("");
    //        }
    
    
        }
    
        public String formatString(int input){
            String result = "";
            if(input > 1000){
              result = input +"";
            }else{
                int length = (input+"").length();
                if (length == 1){
                    result = "000"+input;
                }
                else if (length == 2){
                    result = "00"+input;
                }else {
                    result = "0"+input;
                }
            }
            return result;
        }
    
        public static void main(String[] args) {
            SerialNumberGenerator generator = new SerialNumberGenerator();
            String result = generator.getNextValue("jiao");
            System.out.println("======"+result+"======");
        }
    }
  • 相关阅读:
    CF1037H
    CF1296F
    CF1446F
    CF1175G
    CF1146G
    CF1303G
    CF1067D
    CF1477E
    COJ16G
    ZJOI2018 迷宫
  • 原文地址:https://www.cnblogs.com/jiaoyiping/p/3833551.html
Copyright © 2011-2022 走看看