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

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

一、hibernate的标签

1.1hibernate基本映射

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

  • auto-import,package属性:
    Query query = session.createQuery("from User");中如果我们将属性auto-import设置为false,则User必须加上完整的包名,当然默认是true,即自动导入。在User.hbm.xml中如果我们在<hibernate-mapping>中加上package="cn.itcast.hibernate",则后面的class标签中就不需要加包名了。
    如:
<hibernate-mapping package="cn.itcast.model">
    <class name="User" table="_user">
        <id name="id" length="36"></id>
        <property name="name" unique="true" not-null="true" length="20"></property>
        <property name="password" not-null="true" length="10"></property>
        <property name="createTime"></property>
        <property name="expireTime"></property>
    </class>
</hibernate-mapping>
  • table 属性:
    在实体类中实体名是User,当我们不指定table时默认表明也是User,但是我们也可以使用table标签指定表名<class name="User" table="_user">

  • 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的配置文件中)<property name="hibernate.hbm2ddl.auto">update</property>。如果没有发生改变则不会进行重建。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容