<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    xih  
    日歷

    導(dǎo)航

    常用鏈接

    留言簿(2)

    隨筆檔案

    搜索

    •  

    最新評(píng)論

    閱讀排行榜

    評(píng)論排行榜

     

    2009年3月30日

    在查詢(xún)時(shí)報(bào)下面的錯(cuò)誤,使用的是hibernate,oracle數(shù)據(jù)庫(kù),并做了集群
    WARN - SQL Error: 17002, SQLState: null
    ERROR - Io 異常:Software caused connection abort: recv failed
    請(qǐng)問(wèn)是什么原因造成的,謝謝!

    posted @ 2010-09-02 10:37 費(fèi)思量 閱讀(511) | 評(píng)論 (0)編輯 收藏
     
    ???參考hibernate對(duì)hql語(yǔ)句的解析,寫(xiě)了對(duì)SQL語(yǔ)句的解析,并生成相應(yīng)的對(duì)象。主要為了自定義查詢(xún)條件進(jìn)行查詢(xún)和對(duì)查詢(xún)結(jié)果進(jìn)行二次查詢(xún)使用。目前只支持簡(jiǎn)單的sql語(yǔ)句的解析,不支持子查詢(xún)的解析。在壓縮包中只給出了解析程序,沒(méi)有包括對(duì)應(yīng)的查詢(xún)對(duì)象。鏈接:程序源碼
    posted @ 2009-04-01 11:34 費(fèi)思量 閱讀(420) | 評(píng)論 (0)編輯 收藏
     
    項(xiàng)目要求能獲得CONNECTION便于對(duì)數(shù)據(jù)庫(kù)的操作,并要求能與spring中的事務(wù)處于同一事務(wù)中。實(shí)現(xiàn):
    1.定義SanHibernateTransactionManager類(lèi),繼承spring中的
    HibernateTransactionManager,便于獲得HibernateTransactionObject。把這個(gè)類(lèi)注入到spring容器中。
    < bean? id ="transactionManager"
    ????????class
    ="com.san.tools.hibernate.SanHibernateTransactionManager" >
    ????????
    < property? name ="sessionFactory" >
    ????????????
    < ref? bean ="sessionFactory" />
    ????????
    </ property >
    ????
    </ bean >

    ?
    public?class?SanHibernateTransactionManager?extends?HibernateTransactionManager{

    ????
    public?Object?getTransactionObj(){
    ????????
    return?super.doGetTransaction();
    ????}

    ????
    ????????
    ????
    public?boolean?existsTransaction(Object?transaction){
    ????????
    return?super.isExistingTransaction(transaction);
    ????}

    ????
    ????
    public?Session?getSession(){
    ????????
    return?SessionFactoryUtils.getSession(this.getSessionFactory(),?true);
    ????}

    ????
    ????
    public?Session?getCurrentSession(){
    ????????HibernateTransactionObject?obj?
    =?(HibernateTransactionObject)this.getTransactionObj();
    ????????
    return?obj.getSessionHolder().getSession();
    ????}

    }

    2.開(kāi)始事務(wù)。
    public ? void ?beginTransaction()? throws ?SQLException {
    ????????
    // TransactionDefinition.PROPAGATION_REQUIRED:支持當(dāng)前的事務(wù),如果不存在就創(chuàng)建一個(gè)新的。

    ????????DefaultTransactionDefinition?transactionDef? = ? new ?DefaultTransactionDefinition(TransactionDefinition.PROPAGATION_REQUIRED);
    ????????
    // 創(chuàng)建一個(gè)TransactionStatus

    ????????TransactionStatus?transactionStatus? = ?transactionManager.getTransaction(transactionDef);
    ????????
    //
    取得綁定到當(dāng)前線程上的session。從HibernateTransactionObject中獲得,這里修改了spring中HibernateTransactionManager.java文件,
    ????????
    // 將private?HibernateTransactionObject改為protected?HibernateTransactionObject

    ????????Session?session? = ?transactionManager.getCurrentSession();
    ??????
    if (session? != ? this .session)
    {
    ????????????System.err.println(
    " session不是同一對(duì)象 "
    );
    ????????}

    ????????
    // 將transactionStatus保存到集合中
    ???????? this .transactionStatuss.add(transactionStatus);
    ????????
    this .beginTransaction? = ? true
    ;
    ????}
    3.提交事務(wù)
    public ? void ?commit()? throws ?HibernateException,SQLException {
    ????????
    // 循環(huán)TransactionStatus集合,直至第一個(gè)transactionStatus被提交時(shí),才真正提交

    ???????? for ( int ?i? = ?transactionStatuss.size()? - ? 1 ;i? >= ? 0 ;i -- ) {
    ????????????DefaultTransactionStatus?transactionStatus?
    =
    ?(DefaultTransactionStatus)transactionStatuss.get(i);
    ????????????transactionManager.commit(transactionStatus);
    ????????}

    ????????transactionStatuss.clear();
    ????}
    4.回滾事務(wù)
    public?void?rollBack(){
    ????????
    for(int?i?=?transactionStatuss.size()?-?1;i?>=?0;i--){
    ????????????DefaultTransactionStatus?transactionStatus?
    =?(DefaultTransactionStatus)transactionStatuss.get(i);
    ????????????transactionManager.rollback(transactionStatus);
    ????????}

    ????????transactionStatuss.clear();
    ????}
    ???????貼出這段代碼一是為了共享一點(diǎn)所得,二是希望能指出中間有什么不正確的地方(心里不是很有底)
    posted @ 2009-03-30 15:32 費(fèi)思量 閱讀(536) | 評(píng)論 (1)編輯 收藏
     
    Copyright © 費(fèi)思量 Powered by: 博客園 模板提供:滬江博客
    主站蜘蛛池模板: 精品韩国亚洲av无码不卡区| 在线观看免费视频一区| 亚洲精品无码av天堂| 青青操免费在线视频| 亚洲AV无码专区在线亚| 亚洲一区二区三区乱码A| 中国人xxxxx69免费视频| 蜜芽亚洲av无码一区二区三区| 情人伊人久久综合亚洲| 一个人免费高清在线观看| 精品无码国产污污污免费网站国产| 色拍自拍亚洲综合图区| 亚洲阿v天堂在线2017免费| 久久精品一区二区免费看| 亚洲av日韩综合一区二区三区| 亚洲精品少妇30p| 免费看美女被靠到爽的视频| 久久久久免费精品国产小说| 国产精品亚洲一区二区三区在线观看| 亚洲av永久无码精品漫画| 亚洲精品tv久久久久| 在线视频观看免费视频18| 成人影片一区免费观看| 亚洲av纯肉无码精品动漫| 亚洲精品视频免费看| 在线亚洲午夜理论AV大片| 手机看片久久国产免费| 免费A级毛片无码无遮挡内射| 91成人免费福利网站在线| 亚洲AV日韩AV永久无码色欲| 亚洲成无码人在线观看| 日本亚洲视频在线| 亚洲国产日韩成人综合天堂| 成人免费在线观看网站| 69视频在线观看高清免费| 最好免费观看高清在线| 一本久久免费视频| 深夜福利在线免费观看| 亚洲精品欧美综合四区| 亚洲国产福利精品一区二区| 亚洲自偷自偷精品|