首页 | 互联网 | IT动态 | IT培训 | Cisco | Windows | Linux | Java | .Net | Oracle | 软件测试 | C/C++ | 嵌入式开发 | 存储世界 | 服务器
网络设备 | IDC | 安全 | 求职招聘 | 数字网校 | 网页设计 | 平面设计 | 技术专题 | 电子书下载 | 教学视频 | 源码下载 | 搜索 | 博客 | 论坛
中国IT实验室Linux频道
中国IT教育
Google
首页 资讯动态 认证考试 新手入门 核心技术 高级技术 J2EE J2ME Java&XML 开源技术 其他技术 RSS订阅 论坛 专题
您现在的位置: 中国IT实验室 >> Java >> 新手入门 >> 开发工具 >> 正文

Java实现的Sequence工具

    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;
        }
    }

[1] [2] [3] [4] [5] 下一页

【责编:Ken】

中国IT教育

相关产品和培训
文章评论
 友情推荐链接
 认证培训
 专题推荐

 ·关于Java框架技术专题
 ·XML全攻略技术专题
 ·JAVA开源技术介绍专题
 ·Java嵌入式开发之J2ME技术专题
 ·超前体验 Oracle 11g的5个新特性…
 ·揭密使用VB.NET的五个实用技巧
 ·Oracle和SQL Server常用函数对比专题…
 ·展现C#世界 C#程序设计专题…
 ·Java入门 Tomcat的配置技巧精华专题…
 ·Oracle RMAN物理备份技术详解…
 今日更新
 社区讨论
 博客论点
 频道精选
 Java 频道导航