Hibernate内置数据类型与java数据类型的对应关系

Hibernate的内置映射类型通常使用和java类型相同的名字,它能够把java基本类型、java时间和日期类型、java大对象类型及JDK中常用的java类映射到相应的标准SQL类型。

1、java基本数据类型对应的Hibernate映射类型

 

2、java时间和日期类型对应的Hibernate映射类型

在java中,代表时间和日期的类型包括:java.util.Date和java.util.Calender。此外,在JDBC API中还提供了3个扩展了java.util.Date类的子类:java.sql.Date、java.sql.Time和java.sql.Timestamp,这3个类分别和标准SQL类型中的DATE、TIME和TIMESTAMP类型对应。

 在标准SQL中,DATE类型表示日期,TIME类型表示时间,TIMESTAMP类型表示时间戳,同时包含日期和时间信息。

 

3、Java大对象类型的Hibernate映射类型

在Java中,java.lang.String可用于表示长字符串(长度超过255),字节数组(byte[])可用于存放图片或长文件的二进制数据。此外,在JDBC API中还提供了java.sql.Clob和java.sql.Blob类型,它们分别和标注SQL中的CLOB和BLOB类型对应。CLOB表示字符串大对象(Character Large Object),BLOB表示二进制大对象(Binary Large Object)。

下图列出了Hibernate映射类型、Java大对象类型、以及标准SQL类型的对应对应关系:

 从上图可以看出,MySql数据库不支持标准SQL的CLOB类型,在MySql中,用TEXT、MEDIUMTEXT及LONGTEXT类型来表示长度超过255的长文本数据,他们的大小分别为0~65 535字节、0~16 777 215字节、0~4 294 967 195字节。

 

4、JDK自带的个别Java类的Hibernate映射类型

下图列出了用于映射JDK自带的个别Java类的Hibernate映射类型,与此对应的标准SQL类型均为VARCHAR类型。

 

猜你喜欢

转载自guoying252166655.iteye.com/blog/2071014