一,hibernate的介绍
hibernate是一款基于ORM的数据库开源框架,所谓的ORM即Object Realational Mapping(对象关系映射),简单的说就是可以让使用该框架的人通过面向对象的语言去操控关系型数据库。与传统的通过JDBC来完成数据库的操作相比,使用该框架可以大大降低开发者的工作量,使其从关系型数据库的各种操作中脱离出来(加载驱动,创建连接等)。JAVA中一个POJO的类是通过hibernate中的SQlSessionFactory维护,然后映射到数据库中相应的表。常用的ORM框架还有Mybatis等。
二,hibernate的使用
hibernate有两种使用方式,一种是通过配置相应的xml文件,然后进行各种初始化工作;另一种便是通过注解的方式。
2.1 项目的搭建
(1)通过Eclipse创建一个maven项目
(2)修改pom.xml文件引入hibernate所需要的一些jar包
本项目maven使用了3.5.4的版本,jdk使用了1.8,hibernate的版本是3.5.4-Final,pom文件内容如下:
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
注意:在最后运行的时候要是报某某class文件找不到的错误,那就是说明引入的jar包少了,在网上搜一下报错信息找到缺少的jar包,然后引入相应的jar包依赖即可,我在刚开始用的时候也是前前后后添加了好几个依赖...以上pom文件在我的机器上是不存在问题的。
2.2 使用
创建项目相应的文件,最后整个项目的主要文件结构如下:
其中domain包下放JavaBean,test包下放相应的测试例子,mapping路径下放映射文件,hibernate.cfg.xml是hibernate的配置文件,里面配置有数据库连接属性等内容,hibernate就是通过该文件进行初始化的。
(1)在domain包下建一个Student类,内容如下:
package com.domain;
public class Student {
private int id;
private String name;
private int age;
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;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
}
该类将与数据库中的表进行映射,类中的属性便为数据库中的字段。
(2)在数据库中进行建表操作
create table tb_student(
id int(10) primary key auto_increment,
name varchar(20),
age int(3)
);
(3)修改hibernate.cfg.xml文件,其实使用properties文件一样可以,但是我比较习惯使用xml文件。具体内容如下:
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
//注意上面的mapping resource节点指明了映射文件所在路径
(4)在mapping文件夹新建一个StudentMapping.hbm.xml文件,该文件配置了映射类的信息,具体内容如下:
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
(5)在com.test包下新建一个测试类,具体内容如下:
package com.test;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import com.domain.Student;
public class HibernateTest {
public static void main(String[] args) {
Configuration config = new Configuration().configure("hibernate.cfg.xml");
//开启会话工厂
SessionFactory sessionFactory = config.buildSessionFactory();
//开启会话
Session session = sessionFactory.openSession();
//开启事务
Transaction tr = session.beginTransaction();
try {
Student stu = new Student();
stu.setName("隔壁老王");
stu.setAge(17);
//保存数据
session.save(stu);
//记得要提交事务,不然不会保存的呀
tr.commit();
}catch(Exception e) {
e.printStackTrace();
tr.rollback();
}
}
}
运行,若控制台打印如下信息则表示执行成功:
查找tb_student表,看看数据是否被保存:
此处由于我们使用了mysql的主键自增,所以在进行保存的时候不用在显式的指明id的值。
常见的错误:
(1)保证自己的mysql在本地是可以被访问的
(2)hibernate.cfg.xml中关于数据库的配置信息要替换成自己的
(3)如何插入中文报错,说明数据库的默认编码方式不对,需要设置为utf-8。
下一节将记录hibernate注解的使用。