現在做了一個關於hibernate的練習,感覺與寫JDBC最不同的地方就是不要寫sql,不要再把從數據庫中取到的值再一一賦給相應對象,只要填寫相應的配置文件就行,這樣可以減少掉很多工作。
首先愛你,我們來看下對象關係映射(ORM),它是hibernate的核心設計思想。
下面是應用百度百科的說法:
一般的ORM包括以下四部分:
一個對持久類對象進行CRUD操作的API;
一個語言或API用來規定與類和類屬性相關的查詢;
一個規定mapping metadata的工具;
一種技術可以讓ORM的實現同事務對象一起進行dirty checking, lazy association fetching以及其他的優化操作。
下面梳理下這個流程,首先設置一個配置文件
1.hibernate.cfg.xml文件配置
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<!--讓hb在運行時顯示實際的sql語句 -->
<property name="show sql">true</property>
<!--使顯示的sql格式化 -->
<property name="format sql">true</property>
<!--設定sql方法,使用的是mysql -->
<property name="dialect">
org.hibernate.dialect.MySQLDialect
</property>
<!--JDBC驅動類的名字 -->
<property name="connection.driver_class">
com.mysql.jdbc.Driver
</property>
<!--數據庫連結串配置 -->
<property name="connection.url">
jdbc:mysql://localhost:3306/xishuizhipan
</property>
<!--數據庫用戶名 -->
<property name="connection.username">root</property>
<!--數據庫密碼配置 -->
<property name="connection.password">netjava</property>
<!-- <property name="hbm2ddl.auto">create</property>--><!--自動創建表 -->
</session-factory>
</hibernate-configuration>
2.設定Userinfo的pojo類
private int id;
private String name;
private String psw;
private String signature;
。。。。。set和get方法
3.Userinfo到db的存取,Userinfo.hbm.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<!-- 指定類到表的映射 -->
<class name="test.pojo.Userinfo" table="userinfo">
<!--主鍵id的生成機制:native將自動根據數據庫生成,mysql是自增長方式 -->
<id name="id" column="id">
<generator class="native"></generator>
</id>
<!--設定Userinfo類每個屬性到userinfo表中對應列名的映射 -->
<property name="name" column="name" />
<property name="psw" column="psw"/>
<property name="signature" column="signature"/>
<property name="sex" column="sex"/>
<property name="age" column="age"/>
<property name="birthday" column="birthday"/>
<property name="qq" column="qq"/>
<property name="e_mail" column="e_mail"/>
<property name="phone" column="phone"/>
<property name="occupation" column="occupation"/>
<property name="score" column="score"/>
<property name="graduateSchool" column="graduateSchool"/>
<property name="country" column="country"/>
<property name="province" column="province"/>
<property name="head_path" column="head_path"/>
</class>
</hibernate-mapping>
4.把Userinfo.hbm.xml配置文件配置到hibernate.cfg.xml文件中
<!--指定Userinfo這個pojo類的映射文件路徑 -->
<mapping resource="Userinfo.hbm.xml"></mapping>
5.獲得hibernate.Session;對象
public class HBUtils {
private static SessionFactory sessionFactory;
//取得根據hibernate.cfg.xml中配置的數據庫的一個session對象
//這個session對象類似與java.sql.connection對象;
public static Session getSession(){
return sessionFactory.openSession();
}
//從hibernate.cfg.xml配置中初始化sessionFactory對象
static {
try{
sessionFactory=new Configuration().configure().buildSessionFactory();
}catch(Throwable ex){
throw new ExceptionInInitializerError(ex);
}
}
}
6.編寫數據庫訪問的DAO類
public int saveUserinfo(Userinfo user){
org.hibernate.Session session=HBUtils.getSession();//得到session對象
org.hibernate.Transaction tx=session.beginTransaction();
tx.begin();//取得一個事務對象,開啓事務
session.save(user);//保存對象到數據庫中
tx.commit();//提交事務
session.close();
return user.getId();
}
經過以上幾步,基本就可以用了
7.出錯總結
(1)少導入包
SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder".
SLF4J: See http://www.slf4j.org/codes.html#StaticLoggerBinder for further
details.
原因:少導入slf4j-simple-1.5.8.jar包
值的注意的是slf4j-api是1.6一下的話,slf4j-simple就必須是1.6一下的,不然不支持
(2)配置文件放錯地方
Caused by: org.hibernate.HibernateException: /hibernate.cfg.xml
not found
本人把hibernate.cfg.xml
配置文件放在WEB-INF文件下,應該放在src目錄下
現階段學的就這些了,以後有想法再補充