网管联盟 | 网管论坛 | 网管u家 | 网管博客 | 网管软件 | 网管求职 | 小游戏 | 网管搜索 | 网管原创 | 网管聚合 | 网管读摘 | 网管焦点 | 世界素材 | 会员投稿 | 会员中心 
中国网管联盟
Windows Linux Cisco 网络技术 数据库 黑客攻防 DotNet Java PHP 认证 新闻资讯 服务器 存储资讯 网络设备 网管学堂 技术专题 焦点 网吧频道
 当前位置: > bitsCN.com > JAVA > 新手入门 > 开发工具 > Java实现的Sequence工具  

Java实现的Sequence工具

2008-04-15  作者:bitsCN整理  来源:中国网管联盟  点评 投稿 收藏

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

网管u家u.bitscn@com

    下面是一个Sequence实现,以数据库MySQL为平台。源代码如下: 中国网管论坛bbs.bitsCN.com

    一、Sequence工具类

网管bitscn_com

   package sequence;

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

网管u家u.bitsCN.com

    /**
    * 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值缓存大小 网管u家u.bitsCN.com

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

网管论坛bbs_bitsCN_com

        /**
         * 获取SequenceUtils的单例对象
         * @return SequenceUtils的单例对象
         */
        public static SequenceUtils getInstance() {
            return _instance;
        } 网管u家u.bitsCN.com

        /**
         * 获取下一个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 {

网管bitscn_com

                    keyInfo = new KeyInfo(keyName, POOL_SIZE);
                    keyMap.put(keyName, keyInfo);
                }
                keyObject = keyInfo.getNextKey();
            } catch (SQLException e) {
                e.printStackTrace();
            }
            return keyObject;
        }
    } 中国网管论坛bbs.bitsCN.com

网管联盟bitsCN_com

网管下载dl.bitscn.com


TAGs
 上一篇:DB2 JDBC驱动程序及其支持的功能简介   下一篇:提示大家一个容易忘记的操作
Java实现的Sequence工具 评论:
loading.. 评论加载中…
评论:请自觉遵守互联网相关政策法规,评论不得超过250字。

验证码: 注册用户
本类热门排行:
最新推荐文章:
网管论坛交流: