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时,触发器捕获这一操作,并为主键赋值,在插入数据库后,再次读取某一识别字段读取已经插入的数据,获取其主键值。