hibernate(二)主键生成策略

hibernate主键生成策略主要指的是在实体类orm的配置

 

  <id name="">

      <generator class="native"></generator>

  </id>

 

  主键生成策略:(7个)

  indentity  :主键自增  ,从数据库中维护主键值,在录入时不用指定主键。   控制台sql 显示为: insert into  Person(name ,sex,age) values(?,?,?)  

  increment :   主键自增,从hibernate中维护,每次插入前 ,会先查询表中最大id值  +1 作为id值   。 控制台SQL 显示为: select   max(id) from person   ,  inserst into  person (id ,name,sex,age) values(?,?,?,?);    具有线程安全问题  ,当对个用户同时插入时, 查询的最大id相同, 提交最慢的把前面的用户覆盖掉了

     sequence  :oracle  数据库 序列 主键生成策略

  Hilo  :高低为算法    hibernate自己生成自动递增  (开发不使用)

  native  :hilo +sequence +indetity    自动三选一  、 根据数据库的方言选择对应的生成策略

  uuid  : 产生随机字符串作为主键    实体类成员变量类型为string 类型

  assigned: 自然主键生成策略,  由开发人员自己录入(表某一列具有主键特征  ,比如:个人信息中的身份证号)   

                            eg :  Person p=new Person();

            p.setId(23434); 

            必须自己录用id值  ,否则会报异常:

            p.setName("dfdf");  p.setSex("男”);  p.setAge(30); 

          session.save(p);

 

 

 

  

 

posted @ 2017-11-28 20:21  逆水行舟!  阅读(135)  评论(0编辑  收藏  举报