0.什么是Hibernate
Hibernate是一个轻量级的JDBC封装,可以使用Hibernate来完成原来我们使用JDBC完成的操作,也就是与数据库的交互操作。它是在Dao层去使用的。总而言之,Hibernate就是一个持久层的ORM框架。
ORM:对象关系映射(英语:Object Relation Mapping,简称ORM,或O/RM,或O/R mapping),指的是将一个Java中的对象与关系型数据库中的表建立一种映射关系,从而操作对象就可以操作数据库中的表。
1.
1.数据库MySQL数据库建表
- 5.6 5.7是比较稳定的版本
- 在数据库中新建表格,SQL命令如下:
CREATE TABLE `cst_customer` (
`cust_id` bigint(32) NOT NULL AUTO_INCREMENT COMMENT '客户编号(主键)',
`cust_name` varchar(32) NOT NULL COMMENT '客户名称(公司名称)',
`cust_source` varchar(32) DEFAULT NULL COMMENT '客户信息来源',
`cust_industry` varchar(32) DEFAULT NULL COMMENT '客户所属行业',
`cust_level` varchar(32) DEFAULT NULL COMMENT '客户级别',
`cust_phone` varchar(64) DEFAULT NULL COMMENT '固定电话',
`cust_mobile` varchar(16) DEFAULT NULL COMMENT '移动电话',
PRIMARY KEY (`cust_id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;
2.新建java工程(使用的是eclipse环境)
- 在java工程中新建lib文件夹,将需要的jar包拷贝进来,我用的hibernate版本为5.0.7.
- 需要拷贝的jar包来自于hibernate-release-5.0.7.Final\lib\required下的所有jar包。
3.创建核心配置文件hibernate.cfg.xml
- 在实体类Customer所在包中,创建一个名称为hibernate.cfg.xml的核心配置文件,
- 首先,将hibernate-core-5.0.7.Final.jar–>/org/hibernate/hibernate-configuration-3.0.dtd中的以下部分复制过来。
- 打开D:\Java\hibernate-release-5.0.7.Final\hibernate-release-5.0.7.Final\project\etchibernate.properties,找到对应的数据库的内容,如下图所示。使用图中的后面四个
- 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</property>
<property name="hibernate.connection.username">root</property>
<property name="hibernate.connection.password">123456</property>
<!-- 配置hibernate的方言 -->
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
<mapping resource="cherry/test/Customer.hbm.xml"/>
</session-factory>
</hibernate-configuration>
4.创建实体类Customer.java
- 在src文件夹子下创建Customer.java,然后对应数据库中的元素,创建相应的变量。
- 然后右击空白处–>source—>generate getter and setter…生成相应的函数:
5.创建映射文件
- 在实体类Customer所在包中,创建一个名称为Customer.hbn.xml的映射文件,在该文件中定义实体类Customer的属性是如何映射到cst_customer表上的。
- 首先,将hibernate-core-5.0.7.Final.jar–>/org/hibernate/hibernate-mapping-3.0.dtd中的以下部分复制过来。
- 然后在里面增加如下:
<hibernate-mapping>
<!-- 建立类与表的映射 -->
<class name="cherry.test.Customer" table="cst_customer">
<!-- 建立类中属性与表中住建的对应 -->
<id name ="cust_id" column="cust_id">
<generator class="native"></generator>
</id>
<!-- 建立类中普通的属性和表中的字段中的对应 -->
<property name="cust_name" column="cust_name"></property>
<property name="cust_source" column="cust_source"></property>
<property name="cust_industry" column="cust_industry"></property>
<property name="cust_level" column="cust_level"></property>
<property name="cust_phone" column="cust_phone"></property>
<property name="cust_mobile" column="cust_mobile"></property>
</class>
</hibernate-mapping>
6.创建测试类
- 在包下下面创建HibernateDemo1.java,内容如下:
package cherry.test;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
//import org.junit.Test;
public class HibernateDemo1 {
public static void main(String[] args) {
// TODO Auto-generated method stub
Configuration configuration = new Configuration().configure();
SessionFactory sessionFactory = configuration.buildSessionFactory();
Session session = sessionFactory.openSession();
Transaction transaction = session.beginTransaction();
Customer customer = new Customer();
customer.setCust_name("tom1");
//String str = customer.getCust_name();
// customer.setCust_source("程序员");
session.save(customer);
transaction.commit();
session.close();
// System.out.println(str);
}
}