频道直达 - 专题 - 新闻 - 技巧 - 组网 - 开发 - 安全 - web编程 - 图像 - 操作系统 - 数据库 - 教育 - 旅游 - 健康 - 时尚 - 驱动 - 软件 - 游戏 - 多媒体 - ERP - 讨论组

Java实现的Sequence工具

来源: 作者:无参的程… 出处:巧巧读书 2008-04-15 进入讨论组
下一页 1 2 3 4 5 

    Sequence是数据库应用中很重要的一个特性,可是有些数据库没有这个特性,比如很流行的开源数据库MySQL就没有Sequence,利用自增主键感觉很不爽,每个表的ID都要设置,通用性也不好。因此考虑为这些不支持Sequence的数据做一个Sequence工具。自动为整个系统提供主键生成策略。

    下面是一个Sequence实现,以数据库MySQL为平台。源代码如下:

    一、Sequence工具类

   package sequence;

    import java.util.HashMap;
    import java.util.Map;
    import java.sql.SQLException;

    /**
    * Created by IntelliJ IDEA.<br>
    * <b>User</b>: leizhimin<br>
    * <b>Date</b>: 2008-4-2 15:21:30<br>
    * <b>Note</b>: Java实现的Sequence工具
    */
    public class SequenceUtils {
        private static SequenceUtils _instance = new SequenceUtils();
        private Map<String, KeyInfo> keyMap = new HashMap<String, KeyInfo>(20); //Sequence载体容器
        private static final int POOL_SIZE = 10;      //Sequence值缓存大小

        /**
         * 禁止外部实例化
         */
        private SequenceUtils() {
        }

        /**
         * 获取SequenceUtils的单例对象
         * @return SequenceUtils的单例对象
         */
        public static SequenceUtils getInstance() {
            return _instance;
        }

        /**
         * 获取下一个Sequence键值
         * @param keyName Sequence名称
         * @return 下一个Sequence键值
         */
        public synchronized long getNextKeyValue(String keyName) {
            KeyInfo keyInfo = null;
            Long keyObject = null;
            try {
                if (keyMap.containsKey(keyName)) {
                    keyInfo = keyMap.get(keyName);
                } else {
                    keyInfo = new KeyInfo(keyName, POOL_SIZE);
                    keyMap.put(keyName, keyInfo);
                }
                keyObject = keyInfo.getNextKey();
            } catch (SQLException e) {
                e.printStackTrace();
            }
            return keyObject;
        }
    }

更多文章 更多内容请看Java环境安装配置Java编程开发手册专题,或进入讨论组讨论。
下一页 1 2 3 4 5 
收藏此文】【 】【打印】【关闭
相关图文阅读
频道图文推荐
健 康 咨 询
时 尚 咨 询
巧巧读书宗旨
相关专题
讨论组问题推荐
站内各频道最新更新文档
站内最新制作专题
热门关键字导读
Photoshop教 程照片处理 照片制作 PS快捷键 抠图
计 算 机 故 障XP系统修复
艺 术 与 设 计设计 流媒体 设计欣赏 边框
计 算 机 安 全ARP
站内频道文章精选
巧巧电脑频道编辑信箱  告诉我们您想看的专题或文章