Hibernate入門

慕課網(wǎng)Hibernate學習筆記

開發(fā)環(huán)境

  1. eclipse mars
  2. hibernate toos

最簡單的例子

  1. 創(chuàng)建java Project

  2. 導入相關依賴

  • 導入hibernate-re...\lib\required中的jar包
  • 導入mysql驅(qū)動
  • 導入Junit4包
  1. 創(chuàng)建hibernate.cfg.xml配置文件
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
        "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
        "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
    <session-factory>
        <property name="connection.user">root</property>
        <property name="connection.password">root</property>
        <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
        <property name="connection.url">jdbc:mysql://localhost:3306/hibernate?useUnicode=true&characterEncoding=UTF-8</property>
        <property name="dialect">org.hibernate.dialect.MySQLDialect</property>
        
        <property name="show_sql">true</property>
        <property name="format_sql">true</property>
        <property name="hbm2ddl.auto">update</property>
    </session-factory>
</hibernate-configuration>
  1. 創(chuàng)建持久化類(javabean)
  • 公有
  • 提供不帶參數(shù)的的構造方法
  • 屬性私有
  • 有setter和getter
public class Student {
    private int id;
    private String name;
    private String sex;
    private int age;

    public Student() {
    }

    public Student(int id, String name, String sex, int age) {
        this.id = id;
        this.name = name;
        this.sex = sex;
        this.age = age;
    }
    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getSex() {
        return sex;
    }

    public void setSex(String sex) {
        this.sex = sex;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }

    @Override
    public String toString() {
        return "Student [id=" + id + ", name=" + name + ", sex=" + sex + ", age=" + age + "]";
    }

}

  1. 創(chuàng)建對象關系映射文件(*.hbm.xml)
    <?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!-- Generated 2016-10-2 16:35:18 by Hibernate Tools 3.5.0.Final -->
<hibernate-mapping>
    <class name="Student" table="STUDENT">
        <id name="id" type="int">
            <column name="ID" />
            <generator class="assigned" />
        </id>
        <property name="name" type="java.lang.String">
            <column name="NAME" />
        </property>
        <property name="sex" type="java.lang.String">
            <column name="SEX" />
        </property>
        <property name="age" type="int">
            <column name="AGE" />
        </property>
    </class>
</hibernate-mapping>

  1. 將映射添加到hibernate.cfg.xml
 <mapping resource="Student.hbm.xml"/>
  1. 創(chuàng)建JUnit測試類
public class StudentTest {
    
    private SessionFactory sessionFactory;
    private Session session;
    private Transaction transaction;
    
    @Before 
    public void init(){
        StandardServiceRegistry registry = new StandardServiceRegistryBuilder().configure("hibernate.cfg.xml").build();
        sessionFactory = new MetadataSources(registry).buildMetadata().buildSessionFactory();
        session = sessionFactory.openSession();
        transaction = session.beginTransaction();
    }
    
    @After
    public void destroy(){
        transaction.commit();
        session.close();
        sessionFactory.close();
    }
    
    @Test
    public void testSaveStudent() {
        Student student = new Student(2, "老王", "男", 13);
        session.save(student);
    }
}

  1. 運行測試即可將數(shù)據(jù)存入數(shù)據(jù)庫

Hibernate相關介紹

hibernat.cfg.xml屬性介紹

  1. hibernat.show_sql:(true|false)是否輸出sql語句到控制臺

  2. hibernat.format_sql: (true|false)是否對輸出的sql語句進行排版

  3. hbm2ddl.auto:(create|update|create-drop|va|idate)
    create每次插入都會刪除原來的表改艇,update會更新原來的表

  4. hibernate.default_schema:(hibernate)設置默認數(shù)據(jù)庫,會在sql語句中的表名前加入前綴

  5. hibernate.dialect:(org.hibernate.dialect.MySQLDialect)數(shù)據(jù)庫方言,可針對特定數(shù)據(jù)庫進行優(yōu)化

  6. hibernate.current_session_contex_class:(thread|jta):
    用于指定getCurrentSession是獲取本地事務還是全局事務

session

  • SessionFactory一個系統(tǒng)一般只創(chuàng)建一個

  • openSession每次獲取的事務時不同事務

  • getCurrentSession獲取的是同一個事務鉴裹,會自動關閉

  • 通過session進行增刪改查

  • 操作前需開啟transaction,完成后提交transaction

*.hbm.xml配置文件介紹

<hibernate-mapping
schema="schema_name"
catalog="catalog_name"http://目錄mysql不支持
default_cascade="cascade_style"http://級聯(lián)風格
default_access="field|property|ClassName"http://訪問策略
default-lazy="true|false"http://加載策略
package="packageName"
>
<id>
<generator class="assigned|native|increment"/>
</id>
//組件屬性
<component name="address" class=""> 
    <property name="" column></property>
</component>

增刪改查

  1. save
  2. update
  3. delete
  4. get //一次性獲取
  5. load // 懶加載

一對多

  1. 實體類中設置多方的set

  2. 在一方的映射文件中設置

<set name="students" table="student" lazy="true" inverse="true" cascade="all">//inverse=true表示由多方維護關聯(lián)關系(多方add元素后,插入時不會出現(xiàn)update)
//cascade="all|save-update|delete|none"
    <key column="gid"></key>
    <one-to-many class="student">
</set>

多對一

  1. 在實體類中設置一方的實例

  2. 在多方映射文件中設置

<many-to-one name="grade" class="Grade" conlumn = "gid"></many-to-one>

HQL語句

select xxx from xxx where xxx group by xxx having xxx order by xxx

使用方法

  1. 大小寫敏感

  2. 簡單例子

    @Test
    public void testQuery(){
        String hql = "from Student as s";
        List<Student> students = session.createQuery(hql).list();
        for(Student student : students){
            System.out.println(student);
        }
    }
  1. 返回Object[]
//只選擇一個屬性則返回object
    @Test
    public void testSelect(){
        String hql = "select s.id, s.name from Student as s";
        Query<Object[]> query = session.createQuery(hql);
        List<Object[]> list = query.list();
        for(Object[] objects : list){
            System.out.println(objects[0]);
            System.out.println(objects[1]);
        }
    }   
  1. 返回list
    @Test
    public void testSelectWithList(){
        String hql = "select new list(s.id, s.name) from Student as s";
        Query query = session.createQuery(hql);
        List<List> lists = query.list();
        for(List list : lists){
            System.out.println(list.get(0));
            System.out.println(list.get(1));
        }
    }
  1. 返回自定義類
//需要有相應的構造方法
String hql = "select new Student(s.id, s.name) from Student as s"
List<Student> lists = query.list();

  1. 沒有指定構造器會調(diào)用默認構造器即無參構造函數(shù)

  2. 集合運算"from grade g where g.students is not empty";

  3. 獲取單個對象

    @Test
    public void testGetOne(){
        String hql="from Student as s where s.id=1";
        Query query = session.createQuery(hql);
        Student student = (Student) query.uniqueResult();
        System.out.println(student.getName());
    }

Hibernate 緩存

一級緩存
  1. 與session相同的生命周期

  2. 示例代碼

    @Test
    public void testCache(){
        Student student1 = session.get(Student.class, 1);
        //清除指定對象緩存
        session.evict(student1);
        //清除所有緩存
        session.clear();
        Student student2 = session.get(Student.class, 1);
        //list()不使用緩存
        String hql = "from Student";
        Query query = session.createQuery(hql);
        List<Student> students = query.list();
        //iterator 先從數(shù)據(jù)庫獲取所有id,判斷緩存中是否有對應記錄四啰,若有則直接使用緩存
        Iterator iterator = query.iterate();
        while(iterator.hasNext()){
            Student student = (Student) iterator.next();
            System.out.println(student.getName());
        }
    }

Hibernate注解

類級別注解
  1. @Entity(name="tableName")
  2. @table(name="", catalog="", schema="")
  3. @Embeddable // 在嵌入類上添加(如Address類)
屬性級別注解

可寫在屬性上也可以寫在get方法上

  1. @Id
    //多個屬性Id實體類需要實現(xiàn)serializable接口
    //字符串主鍵需要通過@Column指定長度

  2. @GeneratedValue(strategy=(), generator="")
    //主鍵生成策略

@GeneratedValue(generator="id")
@GenericGenerator(name="id", strategy="assigned")
  1. @Column(length="", name="", nullable="", insertable="", unique="", updateable="")
  2. @Embedded
    //嵌入類需要@Embeddable
  3. @EmbeddedId
    //嵌入類(需要@Embeddable,實現(xiàn)Serializable接口,有無參構造方法粗恢,覆蓋equals,hashCode)作為主鍵
  4. @Transient
    //忽略某個字段柑晒,不映射到數(shù)據(jù)庫
關聯(lián)映射注解
  1. @OneToOne(cascade=CascadeType.ALl, mappedBy="id")
    //mappedBy設置主控放
    @JoinColumn(name="id", unique=true)

  2. @ManyTOOne(cascade={CascadeType.ALL} fetch=FetchType.EAGER)
    //fetch抓取策略默認積極
    @JoinColumn(name="gid", referenceColumnName="gid")

  3. @OneToMany(cascade={CascadeType.ALL} fetch=FetchType.LAZY)
    @JoinColumn(name="gid")

  4. @ManyToMany(mappedBy="")
    @JoinTable(name="",JoinColumns="",
    inverseJoinColumns={@JoinColumn(name="tid")})

最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市眷射,隨后出現(xiàn)的幾起案子匙赞,更是在濱河造成了極大的恐慌恋追,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,627評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件罚屋,死亡現(xiàn)場離奇詭異苦囱,居然都是意外死亡,警方通過查閱死者的電腦和手機脾猛,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,180評論 3 399
  • 文/潘曉璐 我一進店門撕彤,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人猛拴,你說我怎么就攤上這事羹铅。” “怎么了愉昆?”我有些...
    開封第一講書人閱讀 169,346評論 0 362
  • 文/不壞的土叔 我叫張陵职员,是天一觀的道長。 經(jīng)常有香客問我跛溉,道長焊切,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 60,097評論 1 300
  • 正文 為了忘掉前任芳室,我火速辦了婚禮专肪,結果婚禮上,老公的妹妹穿的比我還像新娘堪侯。我一直安慰自己嚎尤,他們只是感情好,可當我...
    茶點故事閱讀 69,100評論 6 398
  • 文/花漫 我一把揭開白布伍宦。 她就那樣靜靜地躺著芽死,像睡著了一般。 火紅的嫁衣襯著肌膚如雪次洼。 梳的紋絲不亂的頭發(fā)上关贵,一...
    開封第一講書人閱讀 52,696評論 1 312
  • 那天,我揣著相機與錄音滓玖,去河邊找鬼坪哄。 笑死,一個胖子當著我的面吹牛势篡,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播模暗,決...
    沈念sama閱讀 41,165評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼禁悠,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了兑宇?” 一聲冷哼從身側響起碍侦,我...
    開封第一講書人閱讀 40,108評論 0 277
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后瓷产,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體站玄,經(jīng)...
    沈念sama閱讀 46,646評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,709評論 3 342
  • 正文 我和宋清朗相戀三年濒旦,在試婚紗的時候發(fā)現(xiàn)自己被綠了株旷。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,861評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡尔邓,死狀恐怖晾剖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情梯嗽,我是刑警寧澤齿尽,帶...
    沈念sama閱讀 36,527評論 5 351
  • 正文 年R本政府宣布,位于F島的核電站灯节,受9級特大地震影響循头,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜炎疆,卻給世界環(huán)境...
    茶點故事閱讀 42,196評論 3 336
  • 文/蒙蒙 一贷岸、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧磷雇,春花似錦偿警、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,698評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至崩掘,卻和暖如春七嫌,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背苞慢。 一陣腳步聲響...
    開封第一講書人閱讀 33,804評論 1 274
  • 我被黑心中介騙來泰國打工诵原, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人挽放。 一個月前我還...
    沈念sama閱讀 49,287評論 3 379
  • 正文 我出身青樓绍赛,卻偏偏與公主長得像,于是被迫代替她去往敵國和親辑畦。 傳聞我的和親對象是個殘疾皇子吗蚌,可洞房花燭夜當晚...
    茶點故事閱讀 45,860評論 2 361

推薦閱讀更多精彩內(nèi)容