Hibernate教程 class1

你還在爲對數據庫操作的複雜煩心嗎?你還在看sql語句的使用規則嗎?
Hibernate都可以幫你解決。。
做過j2ee開發的騷年們對s2sh都不會陌生吧。H就是hibernate。
現在博主就帶你初嘗hibernate。
首先我們需要了解hibernate是什麼,他能做什麼?
先看百度百科
簡單來說hibernate就是在數據庫和事務之間封裝了一層,我們通過hibernate提供的接口來操縱數據庫。
它能使我們更加簡單和方便的操縱數據庫。
現在我們可以來做我們的第一個hibernate項目了。

首先我們要使用hibernate,就要在項目中導入hibernate的包,細心的博主已經爲你們準備好了。
hibernate的原理就是把Java的model和數據庫中的表互相映射。
我們首先要建立一個javabean的類
我建立了一個student的model類。
package com.wyy.model;

public class Student {

private long id;
private String name;
public long getId() {
return id;
}
public void setId(long id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
這個student類不需要我解釋了吧。。。。

現在我們需要建立hibernate的配置文件,文件名爲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.driver_class">com.mysql.jdbc.Driver</property>
        <property name="connection.url">jdbc:mysql://localhost:3306/hibernate</property>
        <property name="connection.username">root</property>
        <property name="connection.password">123456</property>

       
        <!-- 方言 -->
        <property name="dialect">org.hibernate.dialect.MySQL5Dialect</property>
        <!-- 控制檯顯示SQL -->
        <property name="show_sql">true</property>

        <!-- 自動更新表結構 -->
        <property name="hbm2ddl.auto">update</property>
        
  <mapping resource="com/wyy/model/Student.hbm.xml"/>

    </session-factory>

</hibernate-configuration>


下面解釋一下
   <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
        <property name="connection.url">jdbc:mysql://localhost:3306/hibernate</property>
        <property name="connection.username">root</property>
        <property name="connection.password">123456</property>
這些是連接數據庫的配置文件。連接過mysql數據庫的人都不會陌生吧。。。

<!-- 方言 -->
<property name="dialect">org.hibernate.dialect.MySQL5Dialect</property>
<!-- 控制檯顯示SQL -->
<property name="show_sql">true</property>

第一個是使我們的數據格式更加完備,第二個會在控制檯輸出sql語句,方便我們檢查。
<mapping resource="com/wyy/model/Student.hbm.xml"/>
表示我們的對應規則,就是Java類和數據庫table的對應規則。
 下面我們還需要爲我們的student建立一個對應關係,也就是上面的com/wyy/model/Student.hbm.xml
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
        "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
        "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">

<hibernate-mapping package="com.wyy.model">

<class name="Student" table="t_student">
<id name="id" column="stuId">
<generator class="native"></generator>
</id>
<property name="name"></property>
</class>

</hibernate-mapping>
最後我們測試一下我們的程序是否正確
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
import org.hibernate.cfg.Configuration;
import org.hibernate.service.ServiceRegistry;

import com.wyy.model.Student;

public class StudentTest {

public static void main(String[] args) {
Configuration configuration=new Configuration().configure(); // 實例化配置文件
ServiceRegistry serviceRegistry=new StandardServiceRegistryBuilder().applySettings(configuration.getProperties()).build(); // 實例化服務登記
   SessionFactory sessionFactory=configuration.buildSessionFactory(serviceRegistry); // 獲取Session工廠
   Session session=sessionFactory.openSession(); // 生成一個session
   session.beginTransaction(); // 開啓事務
   
   Student s=new Student();
   s.setName("張三");
   session.save(s);
   
   session.getTransaction().commit(); // 提交事務
   session.close(); // 關閉session
   sessionFactory.close(); // 關閉session工廠
}
}

Hibernate就是那麼簡單。。。後面我會爲大家繼續帶來hibernate的深度介紹,。。。。
發佈了27 篇原創文章 · 獲贊 17 · 訪問量 10萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章