首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 软件管理 > 软件架构设计 >

hibernate数据类型与OR投射

2012-09-06 
hibernate数据类型与OR映射1、Hibernate基本数据类型Hibernate基本类型JAVA类型标准SQL字段类型BooleanBool

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???</id>

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

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

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

?

(2)表/类映射

<class</class>

name:指定POJO类

table:POJO类对应的数据库表

lazy:延迟加载

?

?

?

?

(3)实体映射

<hibernate-mapping>

????????????????????????????????????????</hibernate-mapping>

?

(4)复合主键映射

<composite-id>

<key-property<key-property</composite-id>

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

?

?

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

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

identitysequence (序列):在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.hexuuid.stringnative(本地):根据底层数据库的能力选择identity, sequence 或者hilo中的一个。

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

foreign(外部引用)

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

<generator???</generator>

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