1、主键生成策略
<!--映射配置文件
>映射配置文件名称和位置没法有固定要求
>映射配置文件中的name属性值写实体类相关内容
-- class 标签name属性值实体类全路径
-- id标签和property标签name属性值 实体类的属性名称(注意要完全一样)
-- id标签和property标签中的column属性是可以省略的,如果不写,则生成的字段名与属性名一样,建议写
出,这样比较清析。
-- property标签中 还有一个属性type属性,用于设定字段的类型,我们可以不用使用,这时hibernate会自动
生成相应的类型 --> 主键生成策略
<generator class="increment"></generator> 先查询最主键的最大值,然后加一
<generator class="identity"></generator> identity要求数据库的主键为自增长类型,采用数据库本身提供的主键生成标识符
<generator class="uuid"></generator> uuid要求主键为字符串类型
<generator class="native"></generator> native从idenity、sequence、hilo当中选择一种合适的生成策略
2、hibernate缓存
计算机领域非常通用的概念。
它介于应用程序和永久性数据存储源(如硬盘上的文件或者数据库)之间,
其作用是降低应用程序直接读写永久性数据存储源的频率,从而提高应用的运行性能。 缓存中的数据是存储源总的数据的拷贝。缓存的物理介质通常是内存。 hibernate一级缓存
1、默认打开
2、使用范围:从session创建到session关闭
3、hibernate一级缓存中,存储的数据必须是持久态的数据,瞬时态和托管态的数据不会存储到一级缓存中 hibernate二级缓存
1、目前已经不使用了,使用redis代替
2、二级缓存默认是不打开的,需要通过配置打开
3、二级缓存的范围:是SessionFactory范围(项目范围) 验证一级缓存:
根据uid查询,返回对象(查询数据库,会有sql输出)
再次根据uid查询,返回对象(不会有sql语句输出) 效果如下:
System.out.println("--------------------");
Person p = (Person)ss.get(Person.class,11);
System.out.println(p);
System.out.println("--------------------");
Person p2 = (Person)ss.get(Person.class,11);
System.out.println(p2); --------------------
Hibernate:
select
person0_.uid as uid0_0_,
person0_.uname as uname0_0_,
person0_.pword as pword0_0_,
person0_.addr as addr0_0_
from
t_person person0_
where
person0_.uid=?
Person [uid=11, uname=zs, pword=123, addr=shanghai]
--------------------
Person [uid=11, uname=zs, pword=123, addr=shanghai] 步骤:
-- 首先查询一级缓存, 查询一级缓存如果没发现有相应的数据, 就去执行数据库查询
-- 查询数据库后, 会把查询得到的结果放到一级缓存中
-- 第二次进行查询时, 也会首先进行一级缓存查询, 这时发现数据已经在一级缓存中了, 直接取出就结果, 不会再做数据库的查询
注意: 一级缓存中并不是存储某个对象, 而是把对象的属性值给存到缓存中, 当我们进行第二次查询时, 返回的
p2,其实是用之前存放的属性值给重新构建出来的一个新的对象噢, 这一点大家了解 hibernate一级缓存特性
》持久态会自动更新数据库 所以,可以不用写ss.update(...)方法(********)
》持久态会自动更新数据库的执行过程(注意:最后提交事务时,
比较一级缓存中的内容与快照区的内容是否相同,
相同,不更新,不相同,调用update方法进行更新)
3、hibernate事务
什么是事务?
是指作为单个逻辑工作单元执行的一系列操作,要么完全地执行,要么完全地不执行。
事务处理可以确保除非事务性单元内的所有操作都成功完成,否则不会永久更新面向数据的资源。 事务代码规则写法(重点掌握)
>结构
try{
开启事务
处理代码
提交事务
}catch){
回滚事务
}finally{
释放资源
}
--------------------------------------------------
public void test1() {
SessionFactory sf = null;
Session ss = null;
Transaction tx = null;
try {
sf = HibernateUtils.getSessionFactory();
// 使用sessionFactory创建Session对象
ss = sf.openSession();
// 开启事务
tx = ss.beginTransaction();
// 添加功能
Person p = new Person();
p.setUname("王五");
p.setPword("111");
p.setAddr("黄埔");
// 调用session对象的实现方法,完成添加
ss.save(p);
// 模拟一个异常
int x = 10 / 0;
// 提交事务
tx.commit();
} catch (Exception e) {
// 输出异常信息
//e.printStackTrace();
// 有异常,则回滚事务
/**
* 一直事务回滚失败的原因是数据库的原因,
* mysql数据库只有InnoDB引擎支持事务;
* 默认引擎是MyISAM,不支持事务,
* 所以,需要设置数据库的表结构为InnoDB;
* 即alter table 表名 ENGINE=InnoDB;
* 同时,将方言设置为MySQLInnoDBDialect
*/
if (tx != null) {
ss.clear();
tx.rollback();
System.out.println("事务回滚!");
}
} finally {
// 关闭资源
if (ss != null && ss.isOpen()) {
ss.close();
}
if (sf != null && !sf.isClosed()) {
sf.close();
}
}
}
--------------------------------------------------
4、hibernate绑定session
》session类似于jdbc的connection,为了可以安全使用threadLocal
》hibernate已经帮我们实现了与本地线程的绑定的session
》获取与本地线程绑定的session 第一步:在hibernate核心配置文件中配置
<!--本地线程绑定的session-->