Hibernate概述(5.0.7版本)
- 是一个标准的ORM框架
- 操作对象就相当于操作表结构通过映射文件把对象和表关联起来
- 对JDBC的一个封装
优点:
1、 简化了jdbc的繁琐编码
2、对面向对象特性的良好支持
缺点:
1、不支持动态sql,灵活性较低
2、 不适合大规模的数据处理
开发环境的搭建
1、导入jar包
Hibernate压缩包下lib包下的required包下所有的jar包+log4j+mysql驱动包
2、配置映射文件
写在实体类同包下 推荐命名规则 类名.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>
<!-- name实体类全路径 table表名-->
<class name="com.hemi.bean.User" table="user">
<!-- name实体类属性名 column表中字段名 -->
<id name="id" column="id">
<!-- 规定主键生成策略 -->
<generator class="native"></generator>
</id>
<property name="name" column="name"></property>
<property name="age" column="age"></property>
</class>
</hibernate-mapping>
主键生成策略:最常用两种
native(根据本地数据库支持主键生成方式)
uuid(根据uuid算法生成一个32位16进制的字符串)
3、配置文件
写在src根目录下 推荐命名规则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>
<!-- 配置连接数据库4大参数 -->
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="hibernate.connection.url">jdbc:mysql:///test</property>
<property name="hibernate.connection.username">root</property>
<property name="hibernate.connection.password">123456</property>
<!-- 配置方言 -->
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
<!-- 选配 -->
<!-- 打印sql语句 -->
<property name="show_sql">true</property>
<!-- 格式化sql语句 -->
<property name="format_sql">true</property>
<!-- 映射生成user表 -->
<property name="hbm2ddl.auto">update</property>
<!-- 加载映射配置文件 -->
<mapping resource="com/hemi/bean/User.hbm.xml"/>
</session-factory>
</hibernate-configuration>
4、使用Hibernate APi操作
a、得到工厂对象
//创建Configuration对象
Configuration configuration = new Configuration();
//加载配置文件 默认加载名为 hibernate.cfg.xml的文件
Configuration configure = configuration.configure();
//创建SessionFactory
SessionFactory factory = configure.buildSessionFactory();
System.out.println(factory);
b、打开session
Session session = factory.openSession();
c、开启事务
Transaction transaction = session.beginTransaction();
d、crud操作
//创建对象并设置值
User user=new User();
user.setAge(20);
user.setName("marry1");
//通过save方法添加数据到数据库
session.save(user);
e、提交事务
transaction.commit();
f、关闭session
session.close();
session方法
增和改
save(object);//增
save执行过后对象为持久态
saveOrUpdate(object);
1、插入或修改
2、当没设置存入数据的主键执行save
3、设置了 执行update
4、当主键不存在报错
merge(object);
1、插入或修改 先查询
2、当没设置存入数据的主键执行save
3、设置了 先去查询 如果主键存在 则修改 不存在则插入
4、瞬时态的数据被merge操作后变成游离态,返回的数据为持久态
update(object);//改 建议先查询后修改
查询
get(实体类.class,主键);
一执行马上发生sql语句查询
load(实体类.class,主键);
延迟查询 执行后不马上去查询 当有用到查询结果时才发生sql语句去查询
删
delete(object); //建议先查再删
对象三大状态
1、瞬时态: 刚创建
2、持久态: 被保存到数据库中且被持久化(session缓存中) [既数据库中有session缓存中也有]
3、游离态: 被持久化过后 数据库中有之对应的记录但是脱离了session
快照机制
从数据库查询出的数据会在缓存和快照区各有一个 当调用clear或者close方法刷新缓存时,来和快照区数据比对,有更新就推入数据库