hibernate数据类型与OR映射

1、Hibernate基本数据类型

Hibernate基本类型
 JAVA类型
 标准SQL字段类型
 
Boolean
 Boolean,java.lang.boolean
 BIT
 
Yes_no
 Boolean,java.lang.boolean
 Char(1)(‘Y’/’N’)
 
True_false
 Boolean,java.lang.boolean
 Char(1)(‘Y’/’N’)
 
Byte
 Byte,java.lang.byte
 TINYINT
 
Short
 Short,java.lang.short
 SMALLINT
 
Interger
 Int,java.lang.integer
 INTEGER
 
Long
 Long,java.lang.long
 BIGINT
 
Float
 Float,java.lang.float
 FLOAT
 
Double
 Double,java.lang.Double
 DOUBLE
 
Big_decimal
 Java.math.BigDecimal
 NUMBERIC
 
Character
 Java.lang.string
 CHAR(1)
 
String
 Java.lang.string
 VARCHAR
 
Date
 Java.util.Date,java.sql.Date
 DATE
 
Time
 Java.util.Date,java.sql.Time
 TIME
 
Timestamp
 Java.util.Date,java.sql.TimeStamp
 TIMESTAMP
 
Calender
 Java.util.Calendar
 TIMESTAMP
 
Calender_date
 Java.util.Calendar
 Date
 
Clob
 Java.sql.clob
 CLOB
 
Blob
 Java.sql.blob
 BLOB
 
Binary
 Byte[]
 VARBINARY,BLOB
 
Text
 Java.lang.String
 CLOB
 
Seralizable
 Java.io.serializable
 VARBINARY,BLOB
 
Class
 Java.lang.class
 VARCHAR
 
Local
 Java.util.locale
 VARCHAR
 
Timezone
 Java.util.timezone
 VARCHAR
 
Currency
 Java.util.currency
 VARCHAR
 

 

 

2、OR映射

(1)id映射

<id column="ID" name="id" type="java.lang.String">

    <generator class="uuid.hex"/>

</id>

name:指定POJO类的成员变量名

type:name指定变量的数据类型

column:对应数据库表的主键字段

 

(2)表/类映射

<class name="test.pojo.company" table="company" lazy="false">

</class>

name:指定POJO类

table:POJO类对应的数据库表

lazy:延迟加载

 

 

 

 

(3)实体映射

<hibernate-mapping>

    <class name="test.pojo.company" table="company" >

       <id column="ID" name="id" type="java.lang.String">

           <generator class="uuid.hex"/>

       </id>

       <property column="NAME" name="name" type="java.lang.String"/>

       <property column="ADDRESS" name="address" type="java.lang.String"/>

    </class>

</hibernate-mapping>

 

(4)复合主键映射

<composite-id>

<key-property column="USERID" name="userid" type="java.lang.String"></key-property>

<key-property column="WHEN" name="when" type="java.sql.Date"></key-property>

</composite-id>

复合主键的POJO类需要实现equals和hashcode方法,可以使用apache commons lang包中的工具类实现(commons-lang.jar)

 

 

3、generator子元素,其class属性指定主键生成方式:

increment(递增):用于为long, short或者int类型生成唯一标识。只有在没有其他进程往同一张表中插入数据时才能使用。 在集群下不要使用。

identity :对DB2,MySQL, MS SQL Server, Sybase和HypersonicSQL的内置标识字段提供支持。返回的标识符是long, short 或者int类型的。

sequence (序列):在DB2,PostgreSQL, Oracle, SAP DB, McKoi中使用序列(sequence),而在Interbase中使用生成器(generator)。返回的标识符是long, short或者 int类型的。

hilo (高低位):使用一个高/低位算法来高效的生成long, short或者 int类型的标识符。给定一个表和字段(默认分别是是hibernate_unique_key 和next_hi)作为高位值得来源。高/低位算法生成的标识符只在一个特定的数据库中是唯一的。在使用JTA获得的连接或者用户自行提供的连接中,不要使用这种生成器。

seqhilo(使用序列的高低位):使用一个高/低位算法来高效的生成long, short或者 int类型的标识符,给定一个数据库序列(sequence)的名字。

uuid.hex :用一个128-bit的UUID算法生成字符串类型的标识符。在一个网络中唯一(使用了IP地址)。UUID被编码为一个32位16进制数字的字符串。

uuid.string :使用同样的UUID算法。UUID被编码为一个16个字符长的任意ASCII字符组成的字符串。不能使用在PostgreSQL数据库中

native(本地):根据底层数据库的能力选择identity, sequence 或者hilo中的一个。

assigned(程序设置):让应用程序在save()之前为对象分配一个标示符。

foreign(外部引用)

select:hibernate3中新增的。需要提供一个唯一的标识字段进行二次读取,以获取触发器生成的主键值,通过param子元素进行定义,比如:

<generator class="select">

    <param name="key">key_field</param>

</generator>

该方法主要针对遗留系统的改造工程,一些早期的系统主键依赖于触发器生成。当数据库insert时,触发器捕获这一操作,并为主键赋值,在插入数据库后,再次读取某一识别字段读取已经插入的数据,获取其主键值。

 

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/dyc87112/archive/2009/02/28/3945379.aspx

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值