国产午夜成人免费看片无遮挡_日本免费xxxx色视频_免费人成网上在线观看_黄网址在线永久免费观看

當(dāng)前位置:雨林木風(fēng)下載站 > 技術(shù)開發(fā)教程 > 詳細(xì)頁面

一個用java完成的數(shù)據(jù)庫序列生成器

一個用java完成的數(shù)據(jù)庫序列生成器

更新時間:2022-05-09 文章作者:未知 信息來源:網(wǎng)絡(luò) 閱讀次數(shù):

如果是集群等應(yīng)用這個就不行了,只能在單應(yīng)用的情況下使用
對于每個序列鍵只需在第一次使用時查詢數(shù)據(jù)庫,后面的都將不需要查詢
有非常詳細(xì)的注釋,我就不多說了


package org.shaoye.common.sql;

import java.util.HashMap;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

/**
* 類<code>Key</code>是一個數(shù)據(jù)庫主鍵生成器,用序列號的方式來產(chǎn)生數(shù)據(jù)庫中需要的主鍵值。
* <p>
* <code>Key</code>目前支持的數(shù)據(jù)庫包括Oracle的所有版本、MySql的3.x以上的版本
* 以及所有支持max()函數(shù)的數(shù)據(jù)庫,支持字段類型僅為數(shù)字類型的主鍵,對于字符及其它類型的主鍵尚不提供支持。
* <p>
* 在使用時只需提供表名、字段名(主鍵)以及到數(shù)據(jù)庫的JDBC連接,如果想要獲得message表的id字段的下一個
* 主鍵值時:
* <p><blockquote><pre>
* java.sql.Connection conn = ...;
* org.shaoye.common.sql.Key key = org.shaoye.common.sql.Key.getInstance();
* int keyValue = key.getNextKey("message", "id", conn);
* String sql = "insert into message (id,...) values (" + keyValue + ",...)";
* //執(zhí)行插入操作...
* </pre></blockquote><p>
*
* @author 令少爺(shaoye@vip.sina.com)
* @since magic 0.1
*/
public final class Key {

/**
* key的最大值,默認(rèn)為9223372036854775807,即long類型的最大值
*/
private long max = 9223372036854775807L;

/**
* key的最小值,默認(rèn)為1
* */
private long min = 1L;

/**
* Key的唯一實(shí)例,通過getInstance()方法獲得
* */
private static Key keygen = new Key();

/**
* KeyInfo類的實(shí)例列表,默認(rèn)容量為5個
* */
private HashMap keyList = new HashMap(5); //keyInfo 列表

/**
* 私有的默認(rèn)構(gòu)造方法,防止外部構(gòu)造類的實(shí)例
* */
private Key() {
}

/**
* 獲得Key的唯一實(shí)例
* */
public static Key getInstance() {
return keygen;
}

/**
* 用指定的表和字段獲得key的下一個值,主鍵的值不得超過2147483647
* @param tableName 數(shù)據(jù)庫中的表名,表中必須有一個數(shù)字主鍵
* @param keyName 表(tableName)中的字段名
* @param connJDBC連接,如果欲獲得的key是第一次取值,則必須保證conn能連接到數(shù)據(jù)庫
* @return key的下一個主鍵的int值
* @throws <code>KeyException</code>如果表名或字段名不存在、訪問數(shù)據(jù)庫錯誤或key的值大于2147483647時拋出
*/
public int getNextKey(String tableName, String keyName, Connection conn) throws KeyException {
long value = getNextKeyLong(tableName, keyName, conn);
if (value > 2147483647L) {
 throw new KeyException("Key's value too big,please call getNextKeyLong method!");
}
return (new Long(value)).intValue();
}

/**
* 用指定的表和字段獲得key的下一個值,最大為9223372036854775807
* @param tableName 數(shù)據(jù)庫中的表名,表中必須有一個數(shù)字主鍵
* @param keyName 表(tableName)中的字段名
* @param connJDBC連接,如果欲獲得的key是第一次取值,則必須保證conn能連接到數(shù)據(jù)庫
* @return key的下一個主鍵的long值
* @throws <code>KeyException</code>如果表名或字段名不存在或訪問數(shù)據(jù)庫錯誤時拋出
*/
public long getNextKeyLong(String tableName, String keyName, Connection conn)
throws KeyException {
KeyInfo keyinfo;
String item = tableName + "." + keyName;
try {
 if (keyList.containsKey(item)) {
keyinfo = (KeyInfo) keyList.get(item);
 }
 else {
keyinfo = new KeyInfo(tableName, keyName, conn);
keyList.put(item, keyinfo);
 }
 return keyinfo.getNextKey();
}
catch (SQLException sqle) {
 throw new KeyException(sqle);
}
}

/**
* 用指定的"表<code>.</code>字段"形式的字符串獲得key的下一個值,主鍵的值不得超過2147483647
* @param tableDotField"表.字段"形式的字符串,如:message.id
* @param connJDBC連接,如果欲獲得的key是第一次取值,則必須保證conn能連接到數(shù)據(jù)庫
* @return key的下一個主鍵的int值
* @throws <code>KeyException</code>如果表名或字段名不存在、訪問數(shù)據(jù)庫錯誤或key的值
* 大于2147483647時拋出
*/
public int getNextKey(String tableDotField, Connection conn) throws KeyException {
long value = getNextKeyLong(tableDotField, conn);
if (value > 2147483647L) {
 throw new KeyException("Key's value too big,please call getNextKeyLong method!");
}
return (new Long(value)).intValue();
}

/**
* 用指定的"表<code>.</code>字段"形式的字符串獲得key的下一個值,最大為9223372036854775807
* @param tableDotField"表.字段"形式的字符串,如:message.id
* @param connJDBC連接,如果欲獲得的key是第一次取值,則必須保證conn能連接到數(shù)據(jù)庫
* @return key的下一個主鍵的int值
* @throws <code>KeyException</code>如果表名或字段名不存在或訪問數(shù)據(jù)庫錯誤時拋出
*/
public long getNextKeyLong(String tableDotField, Connection conn) throws KeyException {
int dot_index = tableDotField.indexOf(".");
if (tableDotField.indexOf(".") < 1) {
 throw new KeyException("Unknown Key '" + tableDotField + "'!");
}
String tab = tableDotField.substring(0, dot_index);
String key = tableDotField.substring(dot_index);
return getNextKeyLong(tab, key, conn);
}

/**
* 用指定的表和字段獲得key的當(dāng)前值,主鍵的值不得超過2147483647
* @param tableName 數(shù)據(jù)庫中的表名,表中必須有一個數(shù)字主鍵
* @param keyName 表(tableName)中的字段名
* @param connJDBC連接,如果欲獲得的key是第一次取值,則必須保證conn能連接到數(shù)據(jù)庫
* @return key的當(dāng)前int值
* @throws <code>KeyException</code>如果表名或字段名不存在、訪問數(shù)據(jù)庫錯誤或key的值大于2147483647時拋出
*/
public int getCurrentKey(String tableName, String keyName, Connection conn)
throws KeyException {
long value = getCurrentKeyLong(tableName, keyName, conn);
if (value > 2147483647L) {
 throw new KeyException("Key's value too big,please call getCurrentKeyLong method!");
}
return (new Long(value)).intValue();
}

/**
* 用指定的表和字段獲得key的當(dāng)前值,最大為9223372036854775807
* @param tableName 數(shù)據(jù)庫中的表名,表中必須有一個數(shù)字主鍵
* @param keyName 表(tableName)中的字段名
* @param connJDBC連接,如果欲獲得的key是第一次取值,則必須保證conn能連接到數(shù)據(jù)庫
* @return key的當(dāng)前l(fā)ong值
* @throws <code>KeyException</code>如果表名或字段名不存在或訪問數(shù)據(jù)庫錯誤時拋出
*/
public long getCurrentKeyLong(String tableName, String keyName, Connection conn)
throws KeyException {
KeyInfo keyinfo;
String item = tableName + "." + keyName;
try {
 synchronized (keyList) {
if (keyList.containsKey(item)) {
 keyinfo = (KeyInfo) keyList.get(item);
}
else {
 keyinfo = new KeyInfo(tableName, keyName, conn);
 keyList.put(item, keyinfo);
}
 }
 return keyinfo.getCurrentKey();
}
catch (SQLException sqle) {
 throw new KeyException(sqle);
}
}

/**
* 用指定的"表<code>.</code>字段"形式的字符串獲得key的當(dāng)前值,主鍵的值不得超過2147483647
* @param tableDotField"表.字段"形式的字符串,如:message.id
* @param connJDBC連接,如果欲獲得的key是第一次取值,則必須保證conn能連接到數(shù)據(jù)庫
* @return key的當(dāng)前int值
* @throws <code>KeyException</code>如果表名或字段名不存在、訪問數(shù)據(jù)庫錯誤或key的值
* 大于2147483647時拋出
*/
public int getCurrentKey(String tableDotField, Connection conn) throws KeyException {
long value = getCurrentKeyLong(tableDotField, conn);
if (value > 2147483647L) {
 throw new KeyException("Key's value too big,please call getNextKeyLong method!");
}
return (new Long(value)).intValue();
}

/**
* 用指定的"表<code>.</code>字段"形式的字符串獲得key的當(dāng)前值,最大為9223372036854775807
* @param tableDotField"表.字段"形式的字符串,如:message.id
* @param connJDBC連接,如果欲獲得的key是第一次取值,則必須保證conn能連接到數(shù)據(jù)庫
* @return key的當(dāng)前int值
* @throws <code>KeyException</code>如果表名或字段名不存在或訪問數(shù)據(jù)庫錯誤時拋出
*/
public long getCurrentKeyLong(String tableDotField, Connection conn) throws KeyException {
int dot_index = tableDotField.indexOf(".");
if (tableDotField.indexOf(".") < 1) {
 throw new KeyException("Unknown Key '" + tableDotField + "'!");
}
String tab = tableDotField.substring(0, dot_index);
String key = tableDotField.substring(dot_index);
return getCurrentKeyLong(tab, key, conn);
}
}


/**
* 內(nèi)部類,用來存儲主鍵信息
* */
class KeyInfo {
private long max = 9223372036854775807L;
private long min = 1L;
private long nextKey;
private String tableName;
private String keyName;
private Connection conn = null;
/**
* keyInfo 對象初始化
*/
KeyInfo(String tableName, String keyName, Connection _conn) throws SQLException {
this.tableName = tableName;
this.keyName = keyName;
this.conn = _conn;
retrieveFromDB();
}
int getMax() {
return (new Long(max)).intValue();
}
long getMaxLong() {
return max;
}
int getMin() {
return (new Long(min)).intValue();
}
long getMinLong() {
return min;
}
/**
* 取下一鍵值
*/
int getNextKey() {
return (new Long(getNextKeyLong())).intValue();
}
/**
* 取下一鍵值
*/
synchronized long getNextKeyLong() {
nextKey++;
return nextKey;
}
/**
* 取當(dāng)前鍵值
*/
synchronized int getCurrentKey() {
return (new Long(nextKey)).intValue();
}
/**
* 取當(dāng)前鍵值
*/
synchronized long getCurrentKeyLong() {
return nextKey;
}
/**
* 從數(shù)據(jù)庫中取當(dāng)前最大值
*/
void retrieveFromDB() throws SQLException {
PreparedStatement pstmt = null;
ResultSet rs = null;
int keyFromDB = 0;
String sql = "select max(" + keyName + ") from " + tableName;
try {
 pstmt = conn.prepareStatement(sql);
}
catch (Exception ex) {
 throw new KeyException("Can't connect DataBase!");
}
try {
 rs = pstmt.executeQuery();
}
catch (SQLException sqle) {
 if (pstmt != null)
pstmt.close();
 throw new KeyException(
"'" + keyName + "' or '" + tableName + "' isn't exist in DataBase!",
sqle);
}
try {
 if (rs.next()) {
nextKey = rs.getLong(1);
if (nextKey < min) {
 nextKey = min;
}
 }
 else {
nextKey = min;
 }
}
catch (SQLException sqle) {
 throw (sqle);
}
finally {
 if (rs != null)
rs.close();
 if (pstmt != null)
pstmt.close();
}
}
}

溫馨提示:喜歡本站的話,請收藏一下本站!

本類教程下載

系統(tǒng)下載排行

国产午夜成人免费看片无遮挡_日本免费xxxx色视频_免费人成网上在线观看_黄网址在线永久免费观看

  • <label id="pxtpz"><meter id="pxtpz"></meter></label>
      1. <span id="pxtpz"><optgroup id="pxtpz"></optgroup></span>

        欧美日韩成人在线| 色偷偷成人一区二区三区91| 国产精品99久久不卡二区| 欧美一级日韩一级| 国产精品综合视频| 国产精品国产精品国产专区不蜜 | 亚洲一区二区三区视频在线| 欧美视频在线一区二区三区| 美女爽到高潮91| 国产欧美精品一区二区色综合 | 911精品国产一区二区在线| 蜜臀av一区二区| 国产精品高潮呻吟久久| 欧美视频三区在线播放| 激情成人午夜视频| 一区二区三区不卡视频| 精品欧美乱码久久久久久| 972aa.com艺术欧美| 日韩高清在线电影| 国产精品精品国产色婷婷| 欧美乱妇一区二区三区不卡视频| 国产精品456露脸| 日本不卡123| 亚洲男同1069视频| 久久久久97国产精华液好用吗 | 99在线精品视频| 久久成人综合网| 亚洲影视在线观看| 国产精品成人午夜| 久久综合成人精品亚洲另类欧美 | 免费成人性网站| 亚洲乱码中文字幕综合| 久久久国际精品| 日韩视频中午一区| 欧美精品久久久久久久多人混战 | 色噜噜久久综合| 国产成人综合在线| 免费成人在线影院| 天天影视网天天综合色在线播放| 中文字幕中文在线不卡住| 久久综合九色综合97婷婷| 777欧美精品| 欧美中文字幕不卡| 色婷婷精品大视频在线蜜桃视频 | 91久久久免费一区二区| 国产jizzjizz一区二区| 国产精品一区二区三区99| 久久精品国产成人一区二区三区 | 国产欧美一区二区精品性| 日韩一区二区三区av| 欧美麻豆精品久久久久久| 色妹子一区二区| 91国偷自产一区二区三区观看| 丁香一区二区三区| www.色综合.com| 91浏览器打开| 在线视频你懂得一区| 欧美在线一区二区三区| 欧美日韩亚洲综合一区二区三区 | 欧美一区二区网站| 91精品国产麻豆国产自产在线| 在线成人高清不卡| 日韩欧美不卡一区| 久久综合五月天婷婷伊人| 国产日本亚洲高清| 中文字幕一区二区三区不卡在线| 亚洲日本欧美天堂| 亚洲成人自拍偷拍| 另类小说图片综合网| 国产精品538一区二区在线| 波多野结衣中文一区| 在线观看视频一区| 日韩一区二区三区视频在线观看| 精品美女被调教视频大全网站| 久久久久久久久97黄色工厂| 成人欧美一区二区三区小说| 亚洲一区二区视频| 免播放器亚洲一区| 成人黄色777网| 在线成人av网站| 中文一区在线播放 | 国产精品久久久久久久久免费桃花 | 老司机一区二区| 国产99久久久国产精品潘金网站| 94色蜜桃网一区二区三区| 在线观看www91| xf在线a精品一区二区视频网站| 国产精品黄色在线观看| 日日夜夜精品免费视频| 成人一道本在线| 欧美一区日韩一区| 亚洲情趣在线观看| 国产在线精品一区在线观看麻豆| 色综合咪咪久久| 欧美精品一区二| 五月激情丁香一区二区三区| 成人午夜视频网站| 日韩一区二区麻豆国产| 亚洲免费视频中文字幕| 国产麻豆欧美日韩一区| 欧美美女直播网站| 亚洲自拍偷拍av| aa级大片欧美| 久久天天做天天爱综合色| 亚洲成人福利片| 色吊一区二区三区| 国产精品久久久久婷婷二区次| 久久精品免费观看| 欧美日韩成人综合在线一区二区| 国产精品免费久久| 国产精品一级二级三级| 日韩精品中午字幕| 天堂蜜桃91精品| 欧美在线小视频| 亚洲国产精品99久久久久久久久| 老司机午夜精品99久久| 6080yy午夜一二三区久久| 亚洲国产三级在线| 欧日韩精品视频| 夜夜嗨av一区二区三区中文字幕 | 欧美在线观看视频一区二区三区| 国产精品网曝门| 国产ts人妖一区二区| 久久一区二区三区四区| 狠狠色狠狠色综合系列| 精品黑人一区二区三区久久| 日本强好片久久久久久aaa| 欧美视频三区在线播放| 亚洲在线免费播放| 欧美视频一区二区三区四区| 亚洲一级电影视频| 欧美日韩国产成人在线91| 午夜精品久久久久久不卡8050| 在线观看亚洲一区| 亚洲777理论| 日韩视频中午一区| 国产自产视频一区二区三区| 26uuu国产在线精品一区二区| 国产精品123| 亚洲视频在线一区二区| 日本高清不卡视频| 婷婷国产v国产偷v亚洲高清| 日韩欧美一区二区在线视频| 韩国av一区二区三区在线观看| 久久久99精品久久| 91免费观看在线| 日韩在线观看一区二区| 精品三级av在线| aa级大片欧美| 日日夜夜精品免费视频| 久久久久九九视频| 91豆麻精品91久久久久久| 日韩专区欧美专区| 久久久久久久久久美女| www欧美成人18+| 成人av在线观| 日韩高清一级片| 中文字幕欧美激情一区| 欧美日韩一区二区三区四区五区 | 国产精品久久久久久户外露出 | 久久久影视传媒| 99国产精品一区| 人人超碰91尤物精品国产| 国产亚洲精品7777| 欧美三片在线视频观看| 国产福利一区在线| 午夜成人在线视频| 欧美激情一区二区在线| 4438x成人网最大色成网站| 岛国精品一区二区| 青青草97国产精品免费观看 | 视频一区在线播放| 日本一区二区不卡视频| 91精品国产综合久久精品app | 亚洲成人av电影| 久久久国产综合精品女国产盗摄| 色婷婷综合久久久| 国产白丝网站精品污在线入口 | 亚洲精品视频自拍| 久久久久久久av麻豆果冻| 欧美高清精品3d| 91国偷自产一区二区三区成为亚洲经典 | 国产成人aaa| 秋霞国产午夜精品免费视频| 国产精品国产a级| 精品国产一区二区三区不卡 | 欧美日韩一区久久| 99re成人精品视频| 国产91丝袜在线播放九色| 久久中文娱乐网| 在线不卡中文字幕播放| 91免费精品国自产拍在线不卡| 国产专区欧美精品| 五月婷婷综合在线| 亚洲人成精品久久久久久| 中文字幕一区在线观看视频| 久久久精品免费免费| 久久综合一区二区| 久久久久久久久久久久久夜| 精品国产免费一区二区三区四区|