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

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

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

    MDA/MDD/TDD/DDD/DDDDDDD
    posts - 536, comments - 111, trackbacks - 0, articles - 0
      BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

    HibernateException: Unexpected row count: 0 expected: 1

    Posted on 2009-07-22 11:13 leekiang 閱讀(2452) 評論(0)  編輯  收藏 所屬分類: hibernate
    [org.hibernate.event.def.AbstractFlushingEventListener] - Could not synchronize database state with session
    org.hibernate.HibernateException: Unexpected row count: 0 expected: 1
    ?? ?at org.hibernate.jdbc.NonBatchingBatcher.addToBatch(NonBatchingBatcher.java:32)

    ?? ?先用對象操作得到Person p = get(Person.class,35);
    ?? ?直連得到connection,執行delete person where id=35
    ?? ?
    ?? ?事務提交前hibernate會對對象進行檢查,看屬性是否有變化,如果有變化就會執行update操作。
    ?? ?事務方法內既有對象操作,又有sql時,往往sql先執行,
    ?? ?id=35的記錄已經被刪了,再執行update 35時就會報那個臭名昭著的HibernateException: Unexpected row count: 0 expected: 1,不能同步數據庫狀態
    ?? ?為什么有的記錄刪除時會update,有的卻沒有?開始一直沒找到原因,因為update語句太長了,
    ?? ?后來靈機一動,在映射里加了dynamic-update="true",update語句變成了可愛的update Person set zd=? where ID=?
    ?? ?一查AbstractPerson,發現getZd()被修改了:
    ?? ??? ?public String getZd() {
    ?? ??? ?if (zd != null)
    ?? ??? ??? ?return zd;
    ?? ??? ?else
    ?? ??? ??? ?return "";
    ?? ??? }
    ??? 這樣凡是zd為null的記錄,刪除時都會報錯。
    ?? ?
    ?? ?總結:(1)HQL和sql共用時要小心,一不小心就出現數據不同步,有空看看事務的處理
    ?? ?????? (2)映射的類里的get方法不要隨便修改
    主站蜘蛛池模板: 在线观看特色大片免费视频| 免费在线黄色电影| 成年人免费网站在线观看| 亚洲娇小性xxxx| 无码中文在线二区免费| 在线亚洲午夜片AV大片| 在线A级毛片无码免费真人| 亚洲一卡2卡3卡4卡5卡6卡| 国产网站在线免费观看| 羞羞漫画页面免费入口欢迎你| 无码不卡亚洲成?人片| 中文字幕成人免费高清在线视频| 亚洲第一AAAAA片| 麻豆国产精品免费视频| 伊人久久亚洲综合影院首页| 在线观看亚洲免费| 国产黄色片免费看| 666精品国产精品亚洲 | 久草免费手机视频| 亚洲精品中文字幕乱码影院| 最近最新中文字幕完整版免费高清| 亚洲成a∨人片在无码2023| 亚洲国产一级在线观看| 未满十八18禁止免费无码网站| 亚洲人成免费电影| 亚洲国产成人久久一区久久| 日韩免费人妻AV无码专区蜜桃| 亚洲一区二区三区四区视频 | 久久久精品午夜免费不卡| 亚洲精品视频观看| 国产老女人精品免费视频| 成人性生交大片免费看好| 亚洲a视频在线观看| 免费在线观看亚洲| 日韩人妻无码精品久久免费一 | 国内永久免费crm系统z在线| 亚洲av永久综合在线观看尤物| 亚洲av手机在线观看| 日韩免费在线视频| 色窝窝亚洲AV网在线观看| 亚洲av无码精品网站|