Hibernate 映射类型
hibernate 映射类型
当你准备一个 hibernate 映射文件时,我们已经看到你把 java 数据类型映射到了 rdbms 数据格式。
在映射文件中已经声明使用的 types 不是 java 数据类型,也不是 sql 数据库类型。
这种类型被称为 hibernate 映射类型,可以从 java 翻译成 sql,反之亦然。
在这一章中列举出所有的基础,日期和时间,大型数据对象,和其它内嵌的映射数据类型。
原始类型
| 映射类型 | java 类型 | ansi sql 类型 |
|---|---|---|
| integer | int 或 java.lang.integer | integer |
| long | long 或 java.lang.long | bigint |
| short | short 或 java.lang.short | smallint |
| float | float 或 java.lang.float | float |
| double | double 或 java.lang.double | double |
| big_decimal | java.math.bigdecimal | numeric |
| character | java.lang.string | char(1) |
| string | java.lang.string | varchar |
| byte | byte 或 java.lang.byte | tinyint |
| boolean | boolean 或 java.lang.boolean | bit |
| yes/no | boolean 或 java.lang.boolean | char(1) ('y' or 'n') |
| true/false | boolean 或 java.lang.boolean | char(1) ('t' or 'f') |
日期和时间类型
| 映射类型 | java 类型 | ansi sql 类型 |
|---|---|---|
| date | java.util.date 或 java.sql.date | date |
| time | java.util.date 或 java.sql.time | time |
| timestamp | java.util.date 或 java.sql.timestamp | timestamp |
| calendar | java.util.calendar | timestamp |
| calendar_date | java.util.calendar | date |
二进制和大型数据对象
| 映射类型 | java 类型 | ansi sql 类型 |
|---|---|---|
| binary | byte[] | varbinary (or blob) |
| text | java.lang.string | clob |
| serializable | any java class that implements java.io.serializable | varbinary (or blob) |
| clob | java.sql.clob | clob |
| blob | java.sql.blob | blob |
jdk 相关类型
| 映射类型 | java 类型 | ansi sql 类型 |
|---|---|---|
| class | java.lang.class | varchar |
| locale | java.util.locale | varchar |
| timezone | java.util.timezone | varchar |
| currency | java.util.currency | varchar |


