一.概念初识
hibernate是一个开源的对象关系映射框架,实现了对JDBC的轻量级封装,将pojo(javaBean)与数据库表建立映射关系,是一个全自动的ORM框架,Hibernate在底层自动生成sql语句,能够实现数据的持久化
ORM:Object Relational Mapping.对象关系映射.意味着将对象和与数据库中的表建立一种映射关系,操作对象就可以操作这个表.
二.资源下载
Hibernate资源包地址:http://hibernate.org/orm/. 将下载后的资源,解压后的得到Hibernate的工程目录
lib包是需要使用的工具包,其中required包是必须的包文件,其它的jar包可以根据需要进行使用.
documentation包是相关文档说明.
project是对应Hibernate提供的案例工程
三.案例演示
在本文中,只作最基本的案例演示.开发环境:win+idea
第一步:创建WEB工程,并根据需要导入相关的包,例如数据库驱动包,日志记录包,核心包(必备),C3p0连接池等.
第二步:创建数据库和表文件
第三步:根据建立的表文件中的字段建立实体类,(实体类的名称应和表中的字段最好保持一致)
注意:实体类需要提供无参构造和对相应的set/get方法.这是持久化对象的编写规则.
第四步:根据实体类生成对应的映射文件.
在本案例中,使用的是XML的文件的方式进行关系映射,暂不使用注解.idea能够有效的支持Xml的映射配置.
Myeclipse需要进行相关配置文件设置,才能出现标签代码提示.
idea和Myeclipse均能够自动生成XML文件.
映射文件命名规则 类名.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>
<!-- ORM:Object Relational Mapping,将实体类O和数据库的表R 建立映射关系 -->
<class name="com.itheima.hibernate.domain.Customer" table="cst_customer">
<!-- 类中的属性与表中的主键对应 -->
<id name="cust_id" column="cust_id">
<generator class="native"/>
</id>
<!-- 类中的属性与表中的字段对应 -->
<property name="cust_name" column="cust_name"/>
<property name="cust_source" column="cust_source"/>
<property name="cust_industry" column="cust_industry"/>
<property name="cust_level" column="cust_level"/>
<property name="cust_phone" column="cust_phone"/>
<property name="cust_mobile" column="cust_mobile"/>
</class>
</hibernate-mapping>
第五步:创建Hibernate核心配置文件
命名规则:hibernate.cfg.xml
<?xml version="1.0" encoding="UTF-8"?>
<!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.connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="hibernate.connection.url">jdbc:mysql:///hibernate_day01</property>
<!-- 用户名 -->
<property name="hibernate.connection.username">****</property>
<!-- 密码 -->
<property name="hibernate.connection.password">****</property>
<!-- 数据库的方言:根据底层的数据库生成不同的SQL -->
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
<!-- 配置显示SQL -->
<property name="hibernate.show_sql">true</property>
<!-- 配置格式化SQL -->
<property name="hibernate.format_sql">true</property>
<!-- 配置hbm2ddl -->
<property name="hibernate.hbm2ddl.auto">update</property>
<!-- 加载映射文件 -->
<mapping resource="com/itheima/hibernate/domain/Customer.hbm.xml"/>
</session-factory>
</hibernate-configuration>
第六步.编写测试方法
public class HibernateDemo1 {
@Test
/**
* 保存操作
*/
public void demo1(){
// 加载Hibernate的核心配置文件.
Configuration configuration = new Configuration().configure();
// 创建一个SessionFactory的对象.
SessionFactory sessionFactory = configuration.buildSessionFactory();
// 创建Session(相当于JDBC中的Connection)
Session session = sessionFactory.openSession();
// 开启事务:
Transaction transaction = session.beginTransaction();
// 完成操作:
Customer customer = new Customer();
customer.setCust_name("未来");
session.save(customer);
// 提交事务
transaction.commit();
// 释放资源
session.close();
}
}
执行完测试方法之后,数据库中成功的添加了一条数据,测试成功!!
总结
在Hibernate的配置过程中,需要注意的关键点有两个,一个是类的映射文件,它能够将实体类和数据表成功的对应起来,一个是Hibernate的核心配置文件,它能配置Hibernate所需的所有信息.