在介绍Hibernate之前,可以想一下原始的方法访问数据库,我们需要写JDBC代码,然后重复的每个增删改都需要写一大堆的连接数据库,写SQL语句。这样那面显得繁琐,所以Hibernate很好的解决了这类问题,直接操作对象可以映射到数据库。
Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。 Hibernate可以应用在任何使用JDBC的场合,既可以在Java的客户端程序使用,也可以在Servlet/JSP的Web应用中使用,最具革命意义的是,Hibernate可以在应用EJB的J2EE架构中取代CMP,完成数据持久化的重任。
Hibernate的核心类和接口一共有6个,分别为:Session、SessionFactory、
Transaction、Query、Criteria和Configuration。这6个核心类和接口在任何开发中都会用到。通过这些接口,不仅可以对持久化对象进行存取,还能够进行事务控制。下面这6个接口都会用到。
要点做过简单的介绍,现在怎么搭建环境和使用的技巧和面对的情况后面介绍:
①引入hibernate的jar文件
hibernate3.jar
lib\required*.jar
jpa\hibernate-jpa-2.0-api-1.0.0.Final.jar(不添加会报类找不到的错误)
②配置信息
一般在类路径下面引入hibernate.cfg.xml文件,这个文件是hibernate的主配置文件,一般在hibernate的官方文档中可以拷贝到模版
<!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="hibernate.dialect">
org.hibernate.dialect.MySQLDialect
</property>
<property name="connection.url">
jdbc:mysql:///hibernate_001?useUnicode=true&characterEncoding=utf8
</property>
<property name="connection.driver_class">
com.mysql.jdbc.Driver
</property>
<property name="connection.username">root</property>
<property name="hibernate.connection.password">
heyingxxx
</property>
<!-- 显示生成的sql语句 -->
<property name="show_sql">true</property>
<property name="format_sql">false</property>
<!--
create:先删除,后创建
update:不存在就创建,存在了,结构一样就不做操作,不一样就update
create-drop: 初始化时候创建表(先删除,在创建),SeessionFactory.close时候删除表,可以用于测试
validate:验证表结构,不一样,就抛出异常
-->
<property name="hbm2ddl.auto">update</property>
<mapping resource="com/heying/domain/User.hbm.xml"/>
</session-factory>
</hibernate-configuration>
c3p0数据库连接池:
<!-- C3P0 数据库连接池 -->
<property name="connection.provider_class">
org.hibernate.connection.C3P0ConnectionProvider
</property>
<!-- 使用c3p0连接池 配置连接池的供应商 -->
<property name="c3p0.min_size">1</property>
<!-- 使用c3p0连接池 配置连接池的连接最小数目 -->
<property name="c3p0.max_size">5</property>
<!-- 使用c3p0连接池 配置连接池连接timeout时间 -->
<property name="c3p0.timeout">100</property>
<!-- 使用c3p0连接池 配置连接池的空闲时间,时间过长会断开连接-->
<property name="c3p0.idle_test_period">3000</property>
③建立一个实体类配置上实体映射文件:
User.java:
package com.heying.domain;
/**
* user 实体
* @author Heying_He
*
*/
public class User {
private int id;
private String name;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
User.hbm.xml:
<?xml version="1.0" encoding="UTF-8"?>
<!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.heying.domain">
<class name="User" table="t_user">
<id name="id" column="id" type="int">
<generator class="native"/>
</id>
<property name="name" column="name" type="string" length="20" />
</class>
</hibernate-mapping>
编写测试方法:
package com.heying.domain;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import org.junit.Test;
public class App {
private static SessionFactory sessionFactory = null;
static{
Configuration config = new Configuration();
config.configure("hibernate.cfg.xml");
sessionFactory = config.buildSessionFactory();
}
@Test
public void testSave()throws Exception{
User user = new User();
user.setName("heying_1");
Session session = sessionFactory.openSession();
Transaction tx = session.beginTransaction();
session.save(user);
tx.commit();
session.close();
}
@Test
public void testGet()throws Exception{
Session session = sessionFactory.openSession();
Transaction tx = session.beginTransaction();
User user = (User) session.get(User.class, 1);
System.out.println(user.getName());
tx.commit();
session.close();
}
}
测试结果: