剛接觸hibernate,以一個小例子,來看看如何搭建hibernate開發環境,如何以面向對象的開發方式來達到與數據庫交互的效果。
先看看例子最終的目錄結構:
下面是具體步驟:
1、創建一個普通的java項目。
2、創建用戶庫,並添加hibernate的jar文件,jar文件包括目錄hibernate-3.2\lib下的所有jar文件和hibernate-3.2目錄下的hibernate3.jar文件。
由於我們的項目要使用mySql數據庫,所以這裏加入mysql的jar文件。
3、將用戶庫引入項目。第二步我們創建了用戶庫,但是我們的項目還不知道,所以我們必須將用戶庫引入項目。
4、將hibernate-3.2\etc目錄下的hibernate.cfg.xml、log4j.properties文件拷到項目的src目錄下。
到此爲止,hibernate開發環境就基本上搭好了。接下來就看實例了。
新建java類User,代碼如下:
package hibernate;
import java.util.Date;
public class User {
private String id;
private String userName;
private String password;
private Date createTime;
private Date expireTime;
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getUserName() {
return userName;
}
public void setUserName(String userName) {
this.userName = userName;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public Date getCreateTime() {
return createTime;
}
public void setCreateTime(Date createTime) {
this.createTime = createTime;
}
public Date getExpireTime() {
return expireTime;
}
public void setExpireTime(Date expireTime) {
this.expireTime = expireTime;
}
}
將hibernate-3.2\eg\org\hibernate\auction目錄下的User.hbm.xml文件拷到User所在目錄,並修改該文件。
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping
package="org.hibernate.auction">
<class name="hibernate.User" >
<id name = "id">
<generator class="uuid"></generator>
</id>
<property name="userName"></property>
<property name="password"></property>
<property name="createTime"></property>
<property name="expireTime"></property>
</class>
</hibernate-mapping>
接下來配置hibernate.cfg.xml
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory >
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="hibernate.connection.url">jdbc:mysql://localhost:3306/hibernate</property>
<property name="hibernate.connection.username">root</property>
<property name="hibernate.connection.password">123</property>
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
<property name="hibernate.show_sql">true</property>
<mapping resource="hibernate/User.hbm.xml"/>
</session-factory>
</hibernate-configuration>
新建ExportDB.java文件,用於在mysql裏創建User表。
package hibernate;
import org.hibernate.cfg.Configuration;
import org.hibernate.tool.hbm2ddl.SchemaExport;
public class ExportDB {
public static void main(String [] args){
Configuration cfg = new Configuration().configure();
SchemaExport export = new SchemaExport(cfg);
export.create(true, true);
}
}
注意:執行ExportDB時,你使用的數據庫必須已經存在,我的是hibernate庫。
執行完後,hibernate庫中就會出現我們的user表。
現在看我們具體的操作
新建Client.java類
package hibernate;
import java.util.Date;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
import org.hibernate.classic.Session;
public class Client {
public static void main(String [] args){
//讀取XML文件
Configuration cfg = new Configuration().configure();
//創建sessionFactory
SessionFactory factory = cfg.buildSessionFactory();
Session session = null;
try{
session = factory.openSession();
//開啓事務
session.beginTransaction();
User user = new User();
user.setUserName("王五");
user.setPassword("123");
user.setCreateTime(new Date());
user.setExpireTime(new Date());
//保存user對象
session.save(user);
//提交事務
session.getTransaction().commit();
}catch (Exception e) {
e.printStackTrace();
//事務回滾
session.getTransaction().rollback();
}finally{
if(session != null){
if(session.isOpen()){
session.close();
}
}
}
}
}
執行後,數據庫中就會出現我們添加的數據。
到此爲止,搭建hibernate環境和實例就演示完畢了。可以看出,使用了hibernate後,我們書寫的代碼少了許多,操作數據庫比原來更加方便,hibernate封裝的確實很強悍。