JAVA-Hibernate-SQL类型映射表及Hibernate标识生成策略
Hibernate基本类型 | JAVA类型 | 标准SQL字段类型 | 大小/描述 |
big_decimal | Java.math.BigDecimal | NUMERIC | 精度数值(8位) |
binary | Byte[] | VARBINARY,BLOB | 变长二进制数据 |
blob | Java.sql.Blob | BLOB | 二进制数据 |
boolean | boolean/java.lang.Boolean | BIT | 布尔类型 |
byte | byte/java.lang.Byte | TINYINT | 1字节 |
calender | Java.util.Calendar | TIMESTAMP | 长日期(YYYYMMDDHHMMSS) |
calender_date | Java.util.Calendar | Date | 短日期(YYYY-MM-DD) |
character | java.lang.Character/java.lang.String/char | CHAR(1) | 定长字符 |
class | Java.lang.Class | VARCHAR | 变长字符 |
clob | Java.sql.Clob | CLOB | CLOB |
currency | Java.util.Currency | VARCHAR | 定长字符 |
date | Java.util.Date/java.sql.Date | DATE | 日期 |
double | double/java.lang.Double | DOUBLE | 8字节 |
float | float/java.lang.Float | FLOAT | 4字节 |
interger | int/java.langInteger | INTEGER | 4字节 |
local | Java.util.Locale | VARCHAR | 变长字符 |
long | long/java.lang.Long | BIGINT | 8字节 |
seralizable | Java.io.Serializable及其之类 | VARBINARY,BLOB | 变长二进制数据 |
short | short/java.lang.Short | SMALLINT | 2字节 |
string | Java.lang.String | VARCHAR | 变长字符 |
text | Java.lang.String | CLOB | 字符大对象 |
time | Java.util.Date/java.sql.Time | TIME | 时间(HH:MM:SS) |
timestamp | Java.util.Date/java.sql.TimeStamp | TIMESTAMP | 短日期(YYYY-MM-DD) |
timezone | Java.util.Timezone | VARCHAR | 变长字符 |
true_false | boolean/java.langBoolean | Char(1)( ' T ' / ' F ' ) | 布尔类型 |
yes_no | boolean/java.lang.Boolean | Char(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
JAVA-Hibernate-SQL类型映射表及Hibernate标识生成策略相关推荐
- Hibernate SQL方言集合
Hibernate SQL方言告诉您的Hibernate应用程序应使用哪种SQL语言与您的数据库进行对话. 1. DB2 org.hibernate.dialect.DB2Dialect 2. DB2 ...
- java hibernate 配置_JAVA语言之关于hibernate的核心配置
本文主要向大家介绍了JAVA语言之关于hibernate的核心配置,通过具体的内容向大家展示,希望对大家学习JAVA语言有所帮助. 一.hibernate中的核心配置文件:hibernate.rfg. ...
- log4j显示hibernate sql参数的配置
#下面的两条配置非常重要,设置为trace后,将可以看到打印出sql中 ? 占位符的实际内容 #this is the most important config for showing parame ...
- log4j.properties中的这句话“log4j.logger.org.hibernate.SQL=DEBUG ”该怎么写在log4j.xml里面呢?...
http://www.cnblogs.com/gredswsh/p/log4j_xml_properties.html 请问:log4j.properties中的这句话"log4j.logg ...
- java hibernate sqlserver自增_怎样在hibernate中实现oracle的主键自增策略?
Oracle数据库索引和SQLServer的阐述 Oracle常见表结构 oracle数据库约束条件删除.取消.启用 在很多情况下,我们使用Hibernate在已经建立好数据库的基础上.在oracle ...
- 基于按annotation的hibernate主键生成策略
这里讨论代理主键,业务主键(比如说复合键等)这里不讨论. 一.JPA通用策略生成器 通过annotation来映射hibernate实体的,基于annotation的hibernate主键标识为@Id ...
- jpa基于按annotation的hibernate主键生成策略
JPA注解持久化类很方便,需要jar包:ejb3-persistence.jar下载 一.JPA通用策略生成器 通过annotation来映射hibernate实体的,基于annotation的hi ...
- Hibernate - Java 类型, Hibernate 映射类型及 SQL 类型之间的对应关系
[1]常见的映射关系表 常见的映射对应关系如下表所示: Hibernate映射类型 Java类型 标准SQL类型 字节大小 integer/int java.lang.Integer/int INTE ...
- Hibernate type 与java 和 数据库类型对应
Hibernate type 属性 内置的 basic mapping types 可以大致地分类为: integer, long, short, float, double, character, ...
- hibernate 映射表_Hibernate多对多映射-连接表
hibernate 映射表 Today we will look into Hibernate Many to Many Mapping using XML and annotation config ...
最新文章
- Verilog初级教程(1)认识 Verilog HDL
- Dubbo(十五)springboot工程dubbo整合SpringCloud Hystrix
- 大数据学习笔记29:Hadoop压缩机制演示
- 智能家居系统--选配防盗锁新(转载)
- 批处理定时执行任务_如何让你的西门子Wincc V14,每天定时自动执行某任务
- Zabbix实现自动发现端口并监控
- Wireshark抓包获取QQ好友IP
- 从数学的视角看社交网络
- 天轰穿Visual Studio2005入门.Net2.0系列视频教程
- python 基金绩效归因
- Win10:文件夹取消隐藏选项为灰色,无法勾选
- mediawiki想要升级PHP,mediawiki升级
- 《让大象飞》读书笔记
- Wannafly挑战赛29-御坂美琴(递归模拟)
- 关于GoldWave给Vegas视频添加音频叠加的教程分享
- DIS和EIS(数码防抖和电子防抖)
- Linux 关机与重启
- 坚果投影仪陷入双11刷单漩涡?良性发展才是硬道理!
- JavaWeb--JDBC核心技术
- spring注解日志
热门文章
- 高并发业务接口开发思路(实战)
- Centos在VMware虚拟机上的网络配置一记
- 关于自增、自减运算(vc++6.0)
- EPC(建筑工程总承包)行业解决方案(汉得咨询)
- 浅析刚参加工作的大学生的心理态势
- 在 java 中_关于final 关键字,在Java中,关于final关键字的说法正确的是()
- 【android自定义控件】ProgressBar自定义
- LOJ2319「NOIP2017」列队
- webpack5学习与实战-(一)-webpack的初步认识
- Windows10使用命令行打开3389_如何在Windows 10上安装Python 3和设置本地编程环境