亚洲韩日午夜视频,欧美日韩在线精品一区二区三区,韩国超清无码一区二区三区,亚洲国产成人影院播放,久草新在线,在线看片AV色

您好,歡迎來(lái)到思海網(wǎng)絡(luò),我們將竭誠(chéng)為您提供優(yōu)質(zhì)的服務(wù)! 誠(chéng)征網(wǎng)絡(luò)推廣 | 網(wǎng)站備案 | 幫助中心 | 軟件下載 | 購(gòu)買流程 | 付款方式 | 聯(lián)系我們 [ 會(huì)員登錄/注冊(cè) ]
促銷推廣
客服中心
業(yè)務(wù)咨詢
有事點(diǎn)擊這里…  531199185
有事點(diǎn)擊這里…  61352289
點(diǎn)擊這里給我發(fā)消息  81721488
有事點(diǎn)擊這里…  376585780
有事點(diǎn)擊這里…  872642803
有事點(diǎn)擊這里…  459248018
有事點(diǎn)擊這里…  61352288
有事點(diǎn)擊這里…  380791050
技術(shù)支持
有事點(diǎn)擊這里…  714236853
有事點(diǎn)擊這里…  719304487
有事點(diǎn)擊這里…  1208894568
有事點(diǎn)擊這里…  61352289
在線客服
有事點(diǎn)擊這里…  531199185
有事點(diǎn)擊這里…  61352288
有事點(diǎn)擊這里…  983054746
有事點(diǎn)擊這里…  893984210
當(dāng)前位置:首頁(yè) >> 技術(shù)文章 >> 文章瀏覽
技術(shù)文章

sql server2005 jdbc解決自動(dòng)增長(zhǎng)列

添加時(shí)間:2012-12-31 20:33:14  添加: 思海網(wǎng)絡(luò) 

背景:系統(tǒng)要支持多種數(shù)據(jù)庫(kù),統(tǒng)一insert的時(shí)候獲取自動(dòng)增長(zhǎng)列的處理方式

問(wèn)題1:insert+select方案

sqlserver2000可以使用insertSql  + SELECT @@IDENTITY AS 'Identity'的方式來(lái)獲得,但是mysql則只能使用executeUpdate(insertSql);

executeQuery('SELECT last_insert_id() ')這樣的方式,否則會(huì)拋出異常:java.sql.SQLException: Can not issue data manipulation statements with executeQuery()

而兩句話分開(kāi)處理,總讓人感覺(jué)不放心,如果并發(fā)操作比較多,存在潛在的危險(xiǎn)。

問(wèn)題2:getGeneratedKeys方案

mysql的驅(qū)動(dòng)支持jdbc3.0,實(shí)現(xiàn)了getGeneratedKeys(),但sqlserver2000 jdbc驅(qū)動(dòng)不支持getGeneratedKeys()

解決思路:

google了一下,據(jù)說(shuō)2005是支持的,所以下下來(lái)看看

下載地址:url:http://download.microsoft.com/download/2/8/9/289dd6a3-eeeb-46dc-9045-d0c6b59bfbc1/sqljdbc_1.1.1501.101_chs.exe

使用小結(jié):

1.2005jdbc驅(qū)動(dòng)是支持jdbc 3.0 的。也就是說(shuō),的確支持getGeneratedKeys()方法。

2.2005jdbc驅(qū)動(dòng)url和包組織變動(dòng)較大。

舉例對(duì)比:

================
2000
================
url="jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=mydb;SelectMethod=cursor"
driverClassName="com.microsoft.sqlserver.jdbc.SQLServerDriver"
================
2005
================
url="jdbc:sqlserver://localhost:1433;DatabaseName=mydb;SelectMethod=cursor"
driverClassName="com.microsoft.jdbc.sqlserver.SQLServerDriver"
如果沒(méi)注意這點(diǎn),必將出現(xiàn)異常:Cannot load JDBC driver class'com.microsoft.jdbc.sqlserver.SQLServerDriver'
做好第二步,出現(xiàn)

3.包的位置:環(huán)境變量CLASSPATH不是必須的。但sqljdbc.jar必須放置在tomcat/common/lib中(如果是租用空間,可能得跟對(duì)方商量了,看是否支持2005的驅(qū)動(dòng))。

否則會(huì)發(fā)生異常:Cannot load JDBC driver class'com.microsoft.sqlserver.jdbc.SQLServerDriver'

測(cè)試示例方法:

    public  String executeUpdate(String sql) throws    SQLException ...{
        Connection conn = getConnection();
        PreparedStatement pstmt = null;
        try ...{
            /**//*注意:jdbc3.0提供了Statement.RETURN_GENERATED_KEYS"用來(lái)指明需要從Statement中獲得自動(dòng)增長(zhǎng)列值,
            如果不設(shè)置該參數(shù),在執(zhí)行g(shù)etGeneratedKeys()時(shí)會(huì)拋出異常:"只有運(yùn)行該語(yǔ)句,生成的鍵才會(huì)可用。"*/
            pstmt = conn.prepareStatement(sql,Statement.RETURN_GENERATED_KEYS);
            pstmt.executeUpdate();
            ResultSet rs =  pstmt.getGeneratedKeys();//為了insert準(zhǔn)備
            if (rs.next())...{
             return rs.getString(1);
            }
            return "-1";
        } catch (SQLException ex) ...{
                throw new SQLException(
                                          "執(zhí)行SQL語(yǔ)句失敗。" +
                                          ex.toString() +
                                          "  sql:"+sql);


        } finally ...{
            freeConnection(conn,pstmt);
        }
    }  

關(guān)鍵字:sql server2005、jdbc、數(shù)據(jù)庫(kù)

分享到:

頂部 】 【 關(guān)閉
版權(quán)所有:佛山思海電腦網(wǎng)絡(luò)有限公司 ©1998-2024 All Rights Reserved.
聯(lián)系電話:(0757)22630313、22633833
中華人民共和國(guó)增值電信業(yè)務(wù)經(jīng)營(yíng)許可證: 粵B1.B2-20030321 備案號(hào):粵B2-20030321-1
網(wǎng)站公安備案編號(hào):44060602000007 交互式欄目專項(xiàng)備案編號(hào):200303DD003  
察察 工商 網(wǎng)安 舉報(bào)有獎(jiǎng)  警警  手機(jī)打開(kāi)網(wǎng)站