标签:highlight 实体 mysql数据库 标识 gen 位置 sql数据库 connect inno
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-->
标签:highlight 实体 mysql数据库 标识 gen 位置 sql数据库 connect inno
原文地址:http://www.cnblogs.com/1020182600HENG/p/7424346.html