3.hibernate的相关标签(hibernate笔记)

首先补充一点:hibernate支持JNDI、JDBC、JTA接口,其中JDBC是本地事务,即只对比如MySQL中的一个数据库起作用,而JTA是全局事务,如对MySQL中的两个数据库aa和bb都起作用。

一、hibernate的标签

1.1hibernate基本映射

实体类<-->表
实体类中的普通属性<-->表字段
采用标签进行映射成数据库表,通过标签将普通属性(即一些数组、集合等)映射成表字段

  • auto-import,package属性:
    Query query = session.createQuery("from User");中如果我们将属性auto-import设置为false,则User必须加上完整的包名,当然默认是true,即自动导入。在User.hbm.xml中如果我们在中加上package="cn.itcast.hibernate",则后面的class标签中就不需要加包名了。
    如:

    
        
        
        
        
        
    

  • table 属性:
    在实体类中实体名是User,当我们不指定table时默认表明也是User,但是我们也可以使用table标签指定表名

  • dynamic-update 和 dynamic-insert 属性:
    第一个属性如果设置为false则在我们使用updata操作的时候它只发出变化字段的sql语句。但是这样做也有缺点,因为如果一条语句没有变化,那么这条语句就不能执行,比如我们之前可以多次运行testSave方法生成同样的数据,但是只有主键不一样,如果设置了第一个属性为false,那么就不行了。第二条语句类似。

  • id 标签:
    这里表示的是单一主键,如果有多个主键,那么就需要使用复合主键了,以后再说。

  • name属性
    指定类中的属性,默认是字段名,可以使用column进行重命名字段名。

  • type属性
    默认会将String转换为数据库中的varchar,将Java中的Date转换为数据库中的日期类型。我们也可以使用此属性指定转换的类型。

  • lenth属性
    默认String转换为varchar是255,但是这里我们可以使用此属性指定长度。

1.2 generator 标签

  • 在Hibernate中主键必须配置生成策略。生成策略有increment、identity、sequence。

  • increment表示可以自增,从一开始。自增在本数据库中是不会重复的,但是在数据库集群中很可能会产生重复。

  • identity表示使用数据库系统(如mysql)的自增,但是如果换成Orecla的话就会出现问题。如果是Orecla则需要配置为sequence属性。同时如果设置为identity的话则id必须是数值型,不能是String。

  • 编码类型
    uuid:这是很常用的。是一个32位的字符串,是Hibernate生成的,一般是不会重复的。一般我们给出长度为36。
    guid:在mysql和sql Server中使用,
    native:也表示自增,但是会根据数据库的类型选择identity或sequence。
    assigned:让应用程序在save之前为对象分配一个标识符。这样需要手动生成主键。即手动给主键一个值。

  • 说明:一般我们都选择手动生成主键,即使用assigned。

1.3 property 标签:

  • column和上面的类似。
  • unique属性:设置唯一性,即不允许重复。
  • not-null属性:非空设置。
  • length:长度

1.4 注意

  • 类名不能是数据库中的关键字。同时类中的属性也不能和数据库中的关键字重名。

  • 实体类的设计原则
    必须要有一个无参的构造方法。
    提供一个标识属性(identifier property)(可选)
    使用非final的类(可选)
    为持久化字段声明访问器(accessors)。
    生成getter和setter方法。(可选)

  • 我们每次在运行ExportDB.java这个类的时候都会重建表,会将之前的数据清掉。这里我们如果指向变更变化了的数据,则需要配置一个属性(在Hibernate的配置文件中)update。如果没有发生改变则不会进行重建。

你可能感兴趣的:(3.hibernate的相关标签(hibernate笔记))