一、简介
Hibernate,是一个开源的ORM框架。所谓的ORM,即object relative mapping,就是对象关系映射。
那什么是对象关系映射?
对象,即java类,又称为实体类,对象一般用来存放数据;
关系:即关系型数据库,例如mySQL、oracle、DB2等等都是关系型数据库;
映射:个人理解为对象和数据库的表一一对应的桥梁,即实体对应数据库表,属性对应表中列。
那为什么需要hibernate?
hibernate提供一套api供开发者调用,通过api,可以简化对数据库的操作,可以让开发者不需要写太多的sql语句就能完成对数据库的操作,例如save(entity),那么hibernate会自动生成一条insert into 语句,然后将entity内的数据插入到数据库中;
hibernate提供不同的方言,不同的方言支持不同的关系型数据库,由于不同的数据库使用起来或多或少都有些不同,如果切换数据库那么很多sql语句必须修改,所以使用hibernate无需修改sql代码,hibernate自身会通过方言生成合适的sql语句,这样就可以达到随心所欲切换数据库;
当然,hibernate还有很多优点,当然这里仅仅罗列比较出色的优点。
学习hibernate,需要学习什么?
除了hibernate提供给开发者的api,还需要学习如何配置!
为什么要配置?
假如需要将一个实体内的数据插入到数据库表中,数据库如何知道数据是插入哪张表,如何知道插入哪一列?所以配置是为了将实体对应到数据库中指定的表,将实体内属性对应到表中的列。
二、实践(一个小案例)
需求:将实体User内数据存入数据库sys_user表中
环境:
1.添加jar包
hibernate3.jar antlr-2.7.6.jar commons-collections-3.1.jar dom4j-1.6.1.jar javassist-3.12.0.GA.jar jta-1.1.jar slf4j-api-1.6.1.jar hibernate-jpa-2.0-api-1.0.0.Final.jarmysql-connector-java-5.1.5-bin.jar
2.使用eclipse创建project工程---hibernate
3.在classpath 创建一个lib文件夹,添加以上jar包,并将jar包add buildpath
4.创建实体类User
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; } @Override public String toString() { return "User [id=" + id + ", name=" + name + "]"; } }
5.在创建sys_user表
create table sys_user( id int primary key not null auto_increment, name varchar(10) ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
6.涉及到数据库操作,自然要连接数据库,在classpath下创建hibernate.cfg.xml文件,配置如下:
<!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 name="foo"> <!-- 配置数据库信息 --> <!-- 配置数据库方言 --> <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property> <!-- 配置数据库url --> <property name="connection.url">jdbc:mysql:///hibernate</property> <!-- 配置数据库驱动(mysql) --> <property name="connection.driver_class">com.mysql.jdbc.Driver</property> <!-- 配置数据库用户名 --> <property name="connection.username">root</property> <!-- 配置数据库密码 --> <property name="hibernate.connection.password">1208</property> <!-- 是否显示sql --> <property name="hibernate.show_sql">true</property> <!-- 导入映射文件 该文件就是实体与数据库表之间的对应关系--> <mapping resource="com/hibernate/User.hbm.xml"/> </session-factory> </hibernate-configuration>
7.创建User.hbm.xml映射文件,配置User和sys_user之间的对应关系
<?xml version="1.0"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <!-- 实体类包路径 --> <hibernate-mapping package="com.hibernate"> <!-- 实体的名称、对应表名 --> <class name="User" table="sys_user"> <!-- 主键id、主键id类型、在表中的列名 --> <id name="id" type="int" column="id"> <!-- 自动增长 --> <generator class="native"/> </id> <!-- 实体属性名、实体属性类型、在表中的列名 --> <property name="name" type="string" column="name" length="20"/> </class> </hibernate-mapping>
8.测试程序
public class TestHibernate { private static SessionFactory sessionFactory; static { Configuration cfg = new Configuration(); //用来维护配置文件的类 cfg.configure("hibernate.cfg.xml"); // 读取指定的主配置文件 sessionFactory = cfg.buildSessionFactory(); //根据配置文件生成Session工厂 } public static void main(String[] args) { User u = new User(); u.setName("save"); Session session = sessionFactory.openSession(); //打开一个新的Session Transaction tx = session.beginTransaction(); //开始事务,执行操作失败后进行数据回滚 session.save(u);//保存 tx.commit(); //提交事务 session.close(); //关闭Session,释放资源 } }
运行结果:
控制台打印:Hibernate: insert into sys_user (name) values (?)
运行成功!
总结:
调用save方法,传入实体,hibernate根据配置文件一一对应实体和数据表并生成sql语句对数据库执行操作!