第一步:建立一個普通的java工程
第二步:選定工程,右擊 Myeclipse--->Add Hibernate Annotation...導入Hibernate相關的包,及數據庫驅動包,我用的是oracle11g,驅動程序包爲:ojdbc6.jar
第三步:自定義兩個包,示例:cn.com.dao 和 cn.com.pojo,在cn.com.pojo包下建立UserPojo.java類,在cn.com.dao目錄下建立UserDao.java類,代碼分別如下:
package cn.com.pojo;
import java.io.Serializable;
public class UserPojo implements Serializable{
private int userId;
private String userName;
private int age;
public int getUserId() {
return userId;
}
public void setUserId(int userId) {
this.userId = userId;
}
public String getUserName() {
return userName;
}
public void setUserName(String userName) {
this.userName = userName;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
}
package cn.com.dao;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import cn.com.pojo.UserPojo;
public class UserDao {
private static SessionFactory sf = null;
static {
// 讀取hibernate.cfg.xml
Configuration config = new Configuration().configure();
// 創建SessionFactory
sf = config.buildSessionFactory();
}
/**
* 添加用戶方法
*/
public static void addUser() {
Session session = null;
// 事務處理
Transaction tr = null;
try {
session = sf.openSession();
tr = session.beginTransaction();
UserPojo user = new UserPojo();
user.setAge(21);
user.setUserName("lili");
session.save(user);
tr.commit();
System.out.println("添加成功!");
} catch (Exception e) {
System.out.println("添加失敗!");
tr.rollback();
} finally {
session.close();
}
}
/**
* 修改信息方法
*/
public static void updateUser() {
Session session = null;
Transaction tr = null;
try {
session = sf.openSession();
tr = session.beginTransaction();
UserPojo user = (UserPojo) session.get(UserPojo.class, 1);
user.setAge(12);
session.save(user);
tr.commit();
System.out.println("修改成功!");
} catch (Exception e) {
tr.rollback();
System.out.println("修改失敗!");
} finally {
session.close();
}
}
/**
* 刪除用戶方法
*/
public static void deletUser() {
Session session = null;
Transaction tr = null;
try {
session = sf.openSession();
tr = session.beginTransaction();
UserPojo user = (UserPojo) session.get(UserPojo.class, 2);
session.delete(user);
tr.commit();
System.out.println("刪除成功!");
} catch (Exception e) {
tr.rollback();
System.out.println("刪除失敗!");
} finally {
session.close();
}
}
/**
* 查詢用戶
*/
public static void queryUser() {
Session session = null;
try {
session = sf.openSession();
UserPojo user = (UserPojo) session.get(UserPojo.class, 1);
System.out.println(user.getUserName());
} catch (Exception e) {
e.printStackTrace();
} finally {
session.close();
}
}
/**
* @param args
*/
public static void main(String[] args) {
// addUser();
// updateUser();
// deletUser();
queryUser();
}
}
注意:UserPojo.java類要實現序列化接口Serializable
第四步:在cn.com.pojo目錄下建立UserPojo.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="cn.com.pojo.UserPojo" table="h_user">
<!-- 主鍵字段的映射 -->
<id name="userId" column="userid" type="int">
<!-- 指定主鍵生成策略 -->
<generator class="increment"></generator>
</id>
<!-- 普通字段映射 -->
<property name="userName" column="username" type="string"></property>
<property name="age" column="userage" type="int"></property>
</class>
</hibernate-mapping>
第五步:創建跟UserPojo.java類對應的數據庫表,表名爲:h_user 字段分別爲:userid username userage
第六步:建立java對象跟數據庫的關聯,對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">
<!-- Generated by MyEclipse Hibernate Tools. -->
<hibernate-configuration>
<session-factory>
<!-- 配置方言爲Oracle,告訴Hibernate底層生成的sql語句符合Oracle數據庫規範 -->
<property name="dialect">org.hibernate.dialect.OracleDialect</property>
<!-- 配置數據庫 -->
<property name="connection.url">jdbc:oracle:thin:@localhost:1521:oracle</property>
<property name="connection.username">scott</property>
<property name="connection.password">tiger</property>
<property name="connection.driver_class">oracle.jdbc.driver.OracleDriver</property>
<!-- 配置show_sql爲true,在控制檯打印出Hibernate生成的sql語句 -->
<property name="show_sql">true</property>
<mapping resource="cn/com/pojo/UserPojo.hbm.xml"/>
</session-factory>
</hibernate-configuration>
到此,工程完成,工程結構示意圖如下:
此時,轉到UserDao.java類下,main函數處做測試吧!!!