Hibernate筆記2

来源:https://www.cnblogs.com/train99999/archive/2019/07/11/11173441.html
-Advertisement-
Play Games

hibernate實體的狀態 實體Entity有三種狀態,瞬時狀態,持久狀態,脫管狀態 瞬時狀態:transient,session 沒有緩存,資料庫也沒有記錄,oid沒有值 持久狀態:persistent,session有緩存,資料庫也有記錄,oid有值 脫管狀態:detached,session ...


hibernate實體的狀態

實體Entity有三種狀態,瞬時狀態,持久狀態,脫管狀態

瞬時狀態:transient,session 沒有緩存,資料庫也沒有記錄,oid沒有值

持久狀態:persistent,session有緩存,資料庫也有記錄,oid有值

脫管狀態:detached,session沒有緩存,資料庫有記錄,oid有值

瞬時狀態轉持久狀態

public void test1(){
        Configuration cfg = new Configuration().configure();
        //創建會話工廠
        SessionFactory factory = cfg.buildSessionFactory();
        //獲取session對象
        Session session = factory.openSession();
        session.getTransaction().begin();

        //創建一個對象,這個對象就是瞬時狀態
        User user = new User("迪麗熱巴","123");//沒有id,資料庫沒有數據session沒有緩存
        System.out.println(user);//User [uid=0, username=迪麗熱巴, password=123]

        session.save(user);//經過保存後,這個對象就是持久狀態,id有值,資料庫有數據,session有緩存
        System.out.println(user);//User [uid=1, username=迪麗熱巴, password=123]

        session.getTransaction().commit();
        session.clear();
    }

持久狀態轉脫管狀態

public void test2(){
        Configuration cfg = new Configuration().configure();
        //創建會話工廠
        SessionFactory factory = cfg.buildSessionFactory();
        //獲取session對象
        Session session = factory.openSession();
        session.getTransaction().begin();
        //通過get方法可以獲取一個持久狀態對象
        User user = (User) session.get(User.class,1);//執行select語句
        System.out.println(user);
        User user1 = (User) session.get(User.class,1);//不執行select語句,因為有session緩存
        System.out.println(user1);
        session.getTransaction().commit();
        session.clear();
    }

img

把持久狀態轉脫管狀態需要使用session.clear方法

    User user = (User) session.get(User.class,1);//執行select語句
        System.out.println(user);
        session.clear();//清除session
        User user1 = (User) session.get(User.class,1);//執行select語句,因為沒有session緩存
        System.out.println(user1);

執行兩次select

Hibernate: 
    select
        user0_.id as id0_0_,
        user0_.username as username0_0_,
        user0_.password as password0_0_,
        user0_.birthday as birthday0_0_ 
    from
        t_user user0_ 
    where
        user0_.id=?
User [uid=1, username=迪麗熱巴, password=123]
Hibernate: 
    select
        user0_.id as id0_0_,
        user0_.username as username0_0_,
        user0_.password as password0_0_,
        user0_.birthday as birthday0_0_ 
    from
        t_user user0_ 
    where
        user0_.id=?
User [uid=1, username=迪麗熱巴, password=123]

一級緩存,快照,一級緩存刷新

一級緩存:又稱為session級別的緩存,當獲得一側會話(session),hibernate在session中創建多個集合(Map),用於存放操作數據(PO對象),為程式優化服務,如果之後需要相應的數據,hibernate優先從session緩存中獲取,如果有就使用:如果沒有在查詢資料庫,當session關閉時,一級緩存銷毀

快照:與一級緩存一樣的存放位置,對一級緩存數據備份,保證資料庫的數據與一級緩存的數據必須一致。如果一級緩存修改了,在執行commit提交時,將自動刷新一級緩存,執行update語句,將一級緩存的數據更新到資料庫

使用HQL會對數據進行一級緩存,使用SQL不會對數據進行緩存

Query query = session.createQuery("from User");//HQL對數據進行一級緩存
        List<User> list = query.list();
        User user = (User)session.get(User.class,1);//有緩存,不用執行select語句,就能獲取數據

save和persist方法區別

save方法:瞬時態 轉換 持久化 會初始化OID

執行save方法前,設置OID將忽略

如果執行查詢,session緩存移除了,在執行save方法,將會執行insert

public void test1(){
        Configuration cfg = new Configuration().configure();
        SessionFactory factory = cfg.buildSessionFactory();
        Session session = factory.openSession();
        session.getTransaction().begin();
        User user = new User("迪麗熱巴","123");
        user.setUid(13);
        System.out.println(user);//[uid=13, username=迪麗熱巴, password=123]
        //執行save方法前,設置的OID將會忽略,
        session.save(user);//瞬時態轉持久態,執行save方法會立即出發insert語句,從資料庫獲取主鍵的值
        System.out.println(user);//User [uid=1, username=迪麗熱巴, password=123]

        //執行session.clear,將會把緩存移除,再次執行save方法,將會執行insert,sql語句
        session.clear();
        session.save(user);//再次保存,id會自動增長
        System.out.println(user);//[uid=2, username=迪麗熱巴, password=123]
        session.getTransaction().commit();//當事務提交時會自動自行update語句
        session.clear();
    }

persist方法:瞬時態,轉換持久態

persist保存的對象,在保存前,不能設置id,否則會報錯

save和persist都是持久化對象的作用

save因為需要返回一個主鍵值,因此會立即執行Insert語句,

而persist在事務外部調用是則不會立即執行insert語句

在事務內部調用還是會立即執行insert語句的

public void test1(){
        Configuration cfg = new Configuration().configure();
        SessionFactory factory = cfg.buildSessionFactory();
        Session session = factory.openSession();
        session.getTransaction().begin();
        User user = new User("古娜力扎","123");
        //user.setUid(30);persist保存的對象,在保存前,不能設置id,否則會報錯
        session.persist(user);//該方法在事務外不會執行insert sql語句
        session.getTransaction().commit();//當事務提交時會自動自行update語句
        session.clear();
    }

一對多實體類和映射文件

多表關係

多對多:比如老師對應多個學生,學生對應多個老師,有中間表的關係

一對多:一個客戶對應多個訂單,表之間有主表和從表,之間的關係(主外鍵關係)

一個客戶對應多個訂單

img

客戶與訂單文件的映射

    <!--
         描述一對多的關係
         key中column寫的是外鍵名稱
         one-to-many:一對多,裡面寫的class,寫多的一方
        -->
        <set name="orders">
            <key column="customer_id"></key>
            <one-to-many class="domain.Order"></one-to-many>
        </set>
<!--描述customer的關係
        class寫一的一方
        column:寫外鍵
        -->
        <many-to-one name="customer" class="domain.Customer" column="customer_id"/>

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 作為一個樂於分享的人,我希望通過一些成熟優秀的代碼庫,來向大家展示讀源碼思路以及闡述編程方面的技巧,也希望大家從中思考並得到屬於自己的一套編程方法論。 半年以來,已進行72小時時長的源碼解讀分享視頻錄製,額外分享時間未計,雖有諸多不足,依然歡迎進行技術交流,也希望可以影響到更多人參與到分享中來,通過 ...
  • Apache Maven,是一個軟體(特別是Java軟體)項目管理及自動構建工具,由Apache軟體基金會所提供。基於項目對象模型(縮寫:POM)概念,Maven利用一個中央信息片斷能管理一個項目的構建、報告和文檔等步驟。曾是Jakarta項目的子項目,現為獨立Apache項目。1.軟體下載http ...
  • 微服務已經流行很久了。相比前兩年而言,確實很流行了。 微服務流行不是什麼壞事,微服務本身是一個很好的架構思想,架構思想一直在改變,微服務之前的SOA也是不錯的做法。只是,在享受新思想帶來的好處時,卻不要為了新而新。 微服務解決了SOA沒有解決的一些問題,但它並不是萬能的,它本身也並非什麼高大上的新技 ...
  • 一、調試技術 (1)調試流程​:單元測試->集成測試->交測試部 (2)分類:i.靜態調試(說白了就是看代碼,看看有沒有錯);ii.動態測試 1.pdb調試 ​相關連接:https://blog.csdn.net/xc_zhou/article/details/80921483 作者:周小董 2.p ...
  • 這幾天看書的時候看到一個演算法,叫粒子群演算法,這個演算法挺有意思的,下麵說說我個人的理解: 粒子群演算法(PSO)是一種進化演算法,是一種求得近似最優解的演算法,這種演算法的時間複雜度可能會達到O(n!),得到的結果不一定是最優解,往往已經很接近最優解了。最早是Kenny 和 Eberhart於1995年提出的 ...
  • 一、python3中安裝PyMySQL模塊 命令安裝: 或者 2、使用在pyCharm中安裝PyMySQL模塊 二、PyMysql對象說明 1、Connection對象 用於建立與資料庫的連接 創建對象:調用connect()方法 參數host:連接的mysql主機,如果本機是'localhost' ...
  • 一、線程池 Sun在Java5中,對Java線程的類庫做了大量的擴展,其中線程池就是Java5的新特征之一,除了線程池之外,還有很多多線程相關的內容,為多線程的編程帶來了極大便利。為了編寫高效穩定可靠的多線程程式,線程部分的新增內容顯得尤為重要。 有關Java5線程新特征的內容全部在java.uti ...
  • 1.介面編程 1.1背景 隨著互聯網的發展, 尤其是移動互聯為代表的Web3.0時代. 客戶端層出不窮, 以APP、微信、PC瀏覽器為代表, 服務端業務邏輯是基本一致的。那麼有沒有一種方式可以做到”服務端一次編寫, 客戶端隨時接入”呢? 1.2介面編程 API(Application Program ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...