首先补充一点: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>
。如果没有发生改变则不会进行重建。