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时,触发器捕获这一操作,并为主键赋值,在插入数据库后,再次读取某一识别字段读取已经插入的数据,获取其主键值。
减肥瘦身品总汇
值得信赖*脉脉美妆*正品现货谢绝讲价
〓深港商盟〓名品欧衣坊(美国休闲品牌AF系列)
QQ三国游戏币及道具专卖店
小脸红红的瘦身旗舰店
posted on 2009-04-29 08:53
龙华城 阅读(1306)
评论(0) 编辑 收藏 所属分类:
Hibernate