微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

*.hbm.xml映射文件的元素及属性

1、每个持久化对象都需要提供一个以类名命名的映射文件,映射文件需要放在和po类同一目录下。

2、如下是wefepo的映射文件

<hibernate-mapping>
<class name="com.lovo.po.WifePO" table="t_wife">
<id name="id" column="w_id" type="int">
<generator class="foreign">
<param name="property">myMan</param>
</generator>
</id>
<property name="name" column="w_name" type="string"></property>
<property name="age" column="w_age" type="int"></property>
<one-to-one name="myMan" class="com.lovo.po.HusbandPO"
cascade="all">
</one-to-one>
</class>
</hibernate-mapping>

1)<class>元素用于指定需要映射的类和表,name属性指定类名,table属性指定表表名。

2)<id>元素用于设置持久化类的OID与表主键的映射关系,name属性指定持久化类的属性名,column属性用于指定数据库主键列名。

3)<generator>元素用来指定对象标识符生成器,为持久化类的实例生成唯一的主键值。

3、生成器的类型有:

1)Increment:用于为longshort或者int类型生成唯一标识符。只有在没有其他进程往同一张表中插入数据时才能使用。(这是由hibernate自动增长,所以数据库不能设置主键自动增长)。

2)Hilo:使用一个/低位算法高效的生产longshort或者int类型。

3)Uuid.hex:一个128-bitUUID算法生成字符串类型的标识符,UUID被编码为一个3216进制数字的字符串。

4)Identity:对于内部支持标识字段的数据库DB2,MysqL,SybaseMS sql),才可以使用identity关键字生成。返回的标识符是longshort,或者int类型。(由数据库自动增长);

5)Sequence:对于内部支持序列的数据库DB2,Oracle,PostgresqlInterbaseSAP DB,McKoi)才可以使用sequence风格的关键字生成。返回标识符是longshort或者int类型。

6)Native自动根据底层数据库(方言)的能力选择identity,sequence或者hilo中的一个。如果没有指定方言则选择hilo

7)Assigned:让应用程序在保存之前为对象分配一个标识符。这是<generator>元素没有指定是的生成策略。(主键由外部程序员生成,无需hibernate参与)。

8)Select:通过数据库触发器选择一些唯一主键的行并返回主键的值来分配一个主键。

9)Foreign:使用另外一个相关联的对象的标识符。通常和<one-to-one>联合起来使用。

4、<property>子元素用于设定持久化类与字段的映射关系。主要包括nametypecolumnnot-null属性

1)Name:持久化对象的属性名;

2)Column数据库的字段名;

3)Type:通常用来指定hibernate映射数据类型,比如:integerstringcharacterdatetimestampfloatobjectblob等。它是java属性的数据类型与数据库字段数据类型的桥梁,如果不进行类型设定,hibernate它会使用反射来得到这个名字的属性,以此来猜测正确的hibernate类型。

4)Not-null属性中不能为空。

5)Length属性的长度。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。