JAVA-Hibernate-SQL类型映射表及Hibernate标识生成策略

Hibernate基本类型JAVA类型标准SQL字段类型大小/描述
big_decimalJava.math.BigDecimalNUMERIC精度数值(8位)
binaryByte[]VARBINARY,BLOB变长二进制数据
blobJava.sql.BlobBLOB二进制数据
booleanboolean/java.lang.BooleanBIT布尔类型
bytebyte/java.lang.ByteTINYINT1字节
calenderJava.util.CalendarTIMESTAMP长日期(YYYYMMDDHHMMSS)
calender_dateJava.util.CalendarDate短日期(YYYY-MM-DD)
characterjava.lang.Character/java.lang.String/charCHAR(1)定长字符
classJava.lang.ClassVARCHAR变长字符
clobJava.sql.ClobCLOBCLOB
currencyJava.util.CurrencyVARCHAR定长字符
dateJava.util.Date/java.sql.DateDATE日期
doubledouble/java.lang.DoubleDOUBLE8字节
floatfloat/java.lang.FloatFLOAT4字节
intergerint/java.langIntegerINTEGER4字节
localJava.util.LocaleVARCHAR变长字符
longlong/java.lang.LongBIGINT8字节
seralizableJava.io.Serializable及其之类VARBINARY,BLOB变长二进制数据
shortshort/java.lang.ShortSMALLINT2字节
stringJava.lang.StringVARCHAR变长字符
textJava.lang.StringCLOB字符大对象
timeJava.util.Date/java.sql.TimeTIME时间(HH:MM:SS)
timestampJava.util.Date/java.sql.TimeStampTIMESTAMP短日期(YYYY-MM-DD)
timezoneJava.util.TimezoneVARCHAR变长字符
true_falseboolean/java.langBooleanChar(1)( ' T ' / ' F ' )布尔类型
yes_noboolean/java.lang.BooleanChar(1)( ' Y '/ ' N ' )布尔类型
备注:
1.考虑到操作 blob 的字段太复杂一个变换的技巧是 . 实体类用 byte[] 类型 ,  hibernate 类型用 binary ,数据库还是用 blob .这样可以简化一些操作;
 2.type 是String类型,因为在java中没有text类型,mysql中的varchar类型字段和text类型字段在java的映射文件和javaBean中都是String,只不过长度会有限制,一般text类型的字段在java映射文件中的限制长度是65535

Hibernate标识生成策略

标识生成描述
increment(递增)适用于代理主键。由Hibernate自动以递增方式生成。用于为long, short或者int类型天生唯一标识。只有在没有其他进程往同一张表中插进数据时才能使用。在集群下不要使用。
identity适用于代理主键。由底层数据库生成标识符。对DB2,MySQL, MS SQL Server, Sybase和HypersonicSQL的内置标识字段提供支持。返回的标识符是long, short 或者int类型的。
sequence(序列)适用于代理主键。Hibernate根据底层数据库的序列生成标识符,这要求底层数据库支持序列。在DB2,PostgreSQL, Oracle, SAP DB, McKoi中使用序列(sequence),而在Interbase中使用天生器(generator)。返回的标识符是long, short或者 int类型的。
hilo(高低位)适用于代理主键。Hibernate分局high/low算法生成标识符。使用一个高/低位算法来高效的天生long, short或者 int类型标识符。给定一个表和字段(默认分别是是hibernate_unique_key 和next_hi)作为高位值得来源。高/低位算法天生的标识符只在一个特定的数据库中是唯一的。在使用JTA获得的连接或者用户自行提供的连接中,不要使用这种天生器。
seqhilo(使用序列的高低位)适用于代理主键。使用一个高/低位算法来高效的天生long, short或者 int类型标识符,给定一个数据库序列(sequence)的名字。
uuid.hex适用于代理主键。Hibernate采用128位的UUID算法生成字符串类型标识符。在一个网络中唯一(使用了IP地址)。UUID被编码为一个32位16进制数字的字符串。
uuid.string适用于代理主键。UUID被编码成一个16字符长的字符串。使用了与上面一样的UUID算法。UUID被编码为一个16个字符长的任意ASCII字符组成的字符串。不能使用在PostgreSQL数据库中。
native(本地)适用于代理主键。根据底层数据库对自动生成标识符的方式,自动选择identity、sequence或hilo中的一个。
assigned(程序设置)适用于自然主键。由Java应用程序负责生成标识符。让应用程序在save()之前为对象分配一个标示符。
foreign(外部引用)适用于代理主键。使用另外一个相关联的对象的标识符。
select hibernate3中新增的。需要提供一个唯一的标识字段进行二次读取,以获取触发器天生的主键值,通过param子元素进行定义。该方法主要针对遗留系统的改造工程,一些早期的系统主键依靠于触发器天生。当数据库insert时,触发器捕捉这一操纵,并为主键赋值,在插进数据库后,再次读取某一识别字段读取已经插进的数据,获取其主键值。
备注:复合主键映射
< 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)

Java 时间和日期 类型 的 Hibernate  映射

hibernate映射类型

Java 类型

标准 SQL 类型

描述

date

util.Date 或者 sql.Date

DATE

YYYY-MM-DD

time

Date    Time

TIME

HH:MM:SS

timestamp

Date   Timestamp

TIMESTAMP

YYYYMMDDHHMMSS

calendar

calendar

TIMESTAMP

YYYYMMDDHHMMSS

calendar_date

calendar

DATE

YYYY-MM-DD




转载于:https://www.cnblogs.com/zwwill/p/7391399.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值