Hibernate學習(2)入門案例
阿新 • • 發佈:2019-02-05
上篇部落格已經把Hibernate概念和其中的核心介面介紹,下面舉個例項新增使用者來介紹Hibernate如何使用。
1、匯入jar檔案
- 匯入antlr-2.7.6.jar
- 匯入commons-collections-3.1.jar
- 匯入dom4j-1.6.1.jar
- 匯入hibernate-jpa-2.0-api-1.0.1.Final.jar
- 匯入hibernate3.jar
- 匯入javassist-3.12.0.GA.jar
- 匯入jta-1.1.jar
- 匯入mysql-connector-java-3.1.13-bin.jar
- 匯入slf4j-api-1.6.1.jar
這一部分沒有過多的解釋,只需要大家瞭解每個
jar檔案包的作用即可。
2、編輯實體
[java] view plaincopyprint?
- package com.entity;
- import java.util.Date;
- publicclass User {
- private String id;
- private String name;
- private String password;
- private Date createTime;
- private Date expireTime;
- public String getId() {
- return id;
- }
- publicvoid setId(String id) {
- this.id = id;
- }
- public String getName() {
- return name;
- }
- publicvoid setName(String name) {
- this.name = name;
- }
- public
String getPassword() {- return password;
- }
- publicvoid setPassword(String password) {
- this.password = password;
- }
- public Date getCreateTime() {
- return createTime;
- }
- publicvoid setCreateTime(Date createTime) {
- this.createTime = createTime;
- }
- public Date getExpireTime() {
- return expireTime;
- }
- publicvoid setExpireTime(Date expireTime) {
- this.expireTime = expireTime;
- }
- }
這一步與普通的JDBC沒有太大的區別,在JDBC中我們也可以通過實體封裝需要的資訊,如果你對面向物件程式設計有一定的瞭解相信不難理解。
3、建立資料庫、表
建立資料庫
建立表
顯示錶結構
這一步就是一個建立資料庫的過程,與我們平常做專案使用的資料庫結構和過程也沒有區別。
4、建立實體對映檔案User.hbm.xml
[html] view plaincopyprint?
- <?xmlversion="1.0"?>
- <!DOCTYPE hibernate-mapping PUBLIC
- "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
- "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
- <hibernate-mapping>
- <classname="com.entity.User">
- <idname="id">
- <generatorclass="uuid"/>
- </id>
- <propertyname="name"/>
- <propertyname="password"/>
- <propertyname="createTime"/>
- <propertyname="expireTime"/>
- </class>
- </hibernate-mapping>
從這一步開始,JDBC開始與Hibernate有一定的區別,這裡我們重點講一下User.hbm.xml的作用。User.hbm.xml的作用簡而言之就是對實體和資料庫中的表進行相呼應,保證我們對實體物件進行的操作都會在資料庫中產生與之對應響應的結果。但僅這樣的配置還有一個問題那就是我們如何將能夠將資料庫中的表與物件進行關聯。這就需要接下來的配置了。
5、建立資料庫連線和對映配置檔案 hibernate.cfg.xml
[html] view plaincopyprint?
- <!DOCTYPE hibernate-configuration PUBLIC
- "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
- "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
- <hibernate-configuration>
- <session-factory>
- <propertyname="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
- <propertyname="hibernate.connection.url">jdbc:mysql://localhost:3306/hibernate_first</property>
- <propertyname="hibernate.connection.username">root</property>
- <propertyname="hibernate.connection.password">root</property>
- <propertyname="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
- <propertyname="hibernate.show_sql">true</property>
- <mappingresource="com/entity/User.hbm.xml"/>
- </session-factory>
- </hibernate-configuration>
這裡的重點區別在於,通過對映說明<mapping resource="com/entity/User.hbm.xml"/>我們可以將資料庫連線和對映進行聯絡,也就是說通過hibernate.cfg.xml的配置,我們就可以找到具體的實體和資料庫表對應關係。到此為止我們所有的配置就進行完畢了,接下來做一個測試。
6、建立測試檔案 Client.java
[java] view plaincopyprint?
- package test;
- import java.util.Date;
- import org.hibernate.Session;
- import org.hibernate.SessionFactory;
- import org.hibernate.cfg.Configuration;
- import com.entity.User;
- publicclass Client {
- publicstaticvoid main(String[] args) {
- //讀取hibernate.cfg.xml檔案
- Configuration cfg = new Configuration().configure();
- //建立SessionFactory
- SessionFactory factory = cfg.buildSessionFactory();
- //取得session
- Session session = null;
- try {
- session = factory.openSession();
- //開啟事務
- session.beginTransaction();