`

hibernate数据类型映射表

阅读更多

Hibernate映射类型分为两种:内置的映射类型和客户化映射类型。内置映射类型负责把一些常见的Java类型映射到相应的SQL类型;此外,Hibernate还允许用户实现UserType或CompositeUserType接口,来灵活地定制客户化映射类型

1.内置映射类型

1).Java基本类型的Hibernate映射类型

Java类型 Hibernate映射类型 标准SQL类型 大小和取值范围

int/Integer int/integer INTEGER 4Byte

long/Long long BIGINT 8Byte

short/Short short SAMLLINT 2Byte

byte/Byte byte TINYINT 1Byte

float/Float float FLOAT 4Byte

double/Double double DOUBLE 8Byte

BigDecimal big_decimal NUMBERIC Numeric(8,2)

char/Character/String character CHAR(1) 定长字符

String string VARCHAR 变长字符

boolean/Boolean boolean BIT 布尔类型

boolean/Boolean yes/no CHAR(1)('Y'/'N') 布尔类型

boolean/Boolean true/false CHAR(1)('T'/'F') 布尔类型

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

Java类型 Hibernate映射类型 标准SQL类型 描述

java.util.Date/java.sql.Date date DATE 日期,yyyy-mm-dd

java.util.Date/java.sql.TIme time TIME 时间,hh:mm:ss

java.util.Date/java.sql.Timestamp timestamp TIMESTAMP 时间戳,yyyymmddhhmmss

java.util.Calendar calendar TIMESTAMP 同上

java.util.Calendar calendar_date DATE 日期,yyyy-mm-dd

* 当程序类型为java.sql.Timestamp, 数据库中表属性类型为timestamp的情况下,即使用户以空值插入数据,数据库系统仍然会自动填充timestamp的值

3). Java 大对象类型的Hibernate映射类型

Java类型 Hibernate映射类型 标准SQL类型 MySql类型 Oracle类型

byte[] binary VARBINARY/BLOB BLOB BLOB

String text CLOB TEXT CLOB

serializable 实现serializable接口的一个java类 VARBINARY/BLOB BLOB BLOB

java.sql.Clob clob CLOB TEXT CLOB

java.sql.Blob blob BLOB BLOB BLOB

* 在应用程序中通过Hibernate来保存java.sql.Clob或者java.sql.Blob实例时,必须包含两个步骤:

a. 在一个数据库事务中先保存一个空的Blob或Clob实例;b. 接着锁定这条记录,更新在步骤(1)中保存的Blob或Clob实例,把二进制数据或长文本数据写到Blob或Clob实例中。

1

2Session session = sessionFactory.openSession();

3Transaction tx = session.beginTransaction();

4Customer customer = new Customer();

5customer.setDescription(Hibernate.createClob("")); //先保存一个空的clob

6session.save(customer);

7session.flush();

8//锁定这条记录

9session.refresh(customer,LockMode.UPGRADE);

10oracle.sql.CLOB clob = (oracle.sql.CLOB) customer.getDescription();

11java.io.Writer pw = clob.getCharacterOutStream();

12pw.write(longText);//longText是一个长度超过255的字符串

13pw.close();

14tx.commit();

15session.close();

* 一个java类型对应多个Hibernate映射类型的场合。例如,如果持久化类的属性为java.util.Date类型,对应的Hibernate映射类型可以是date,time

或timestamp。此时必须根据对应的数据库表的字段的SQL类型,来确定Hibernate映射类型。如果字段为Date类型,则hibernate映射为datge,如果为TIME则为time,如果为TIMESTAMP则为timestamp。

分享到:
评论

相关推荐

    Hibernate数据类型映射表.bmp

    Hibernate数据类型映射表,介绍hibernate中各类型数据的关系!

    JAVA数据类型与Hibernate的类型映射

    这篇博客主要探讨了Java数据类型如何与Hibernate的类型映射进行对应。 首先,Java的基本数据类型在Hibernate中有对应的类型映射。例如,int型在Hibernate中通常映射为Integer类型,因为数据库字段可能允许为空...

    Hibernate数据类型映射及ID

    标题:“Hibernate数据类型映射及ID” 描述:“Hibernate与各数据库数据类型的映射” ### Hibernate数据类型映射 Hibernate作为一款流行的Java持久层框架,它提供了丰富的数据类型映射功能,使得开发者能够更加...

    Java数据类型,Hibernate数据类型,标准sql数据类型之间的对应表

    这里,我们提到了一个名为“Hibernate的映射类型_hibernate_mysql映射类型.doc”的文档,这很可能是一个详细的对照表,列出了Hibernate如何将Java数据类型映射到MySQL数据库的SQL数据类型。MySQL是世界上最流行的...

    hibernate set 集合映射

    1. **集合类型**:Hibernate支持多种集合类型映射,如Set、List、ArrayList、LinkedList、Map等。Set是最常见的集合映射类型,它不允许重复元素,与数据库中的唯一约束相对应。 2. **元素类型**:集合中的每个元素...

    Hibernate数据关联映射与继承策略

    **Hibernate数据关联映射** Hibernate 是一款强大的Java对象关系映射(ORM)框架,它允许开发者将数据库操作转化为对Java对象的操作,简化了数据库编程。在 Hibernate 中,数据关联映射是实现对象与数据库表之间...

    hibernate array 数组映射

    在Hibernate中,数组映射是将数据库表的一列或多列数据映射到Java对象的一个数组属性上。数组可以是基本类型数组或对象类型的数组。这种映射方式简化了数据访问,并提高了代码的可读性和可维护性。 ### 配置数组...

    hibernate动态映射表处理oracle的clob类型

    本主题“hibernate动态映射表处理Oracle的CLOB类型”主要聚焦于如何在Hibernate中有效地管理和操作CLOB字段。在Oracle 10g中,CLOB数据类型的处理有时会遇到一些挑战,尤其是在与ORM框架结合使用时。以下将详细介绍...

    hibernate映射枚举类型

    在Java编程中,枚举类型(Enum)是一种...正确地映射枚举类型可以增强代码的可读性和可维护性,同时减少因数据类型转换导致的潜在错误。在实际开发中,我们应该根据业务场景和枚举特性的需求,选择最合适的映射策略。

    hibernate map 集合映射

    在Java的持久化框架Hibernate中,集合映射是将数据库中的表关系映射到对象的集合属性上,以便更好地管理和操作数据。这篇文章将深入探讨Hibernate中的集合映射机制,包括其基本概念、类型以及如何在实际开发中进行...

    hibernate集合的映射

    在Java的持久化框架Hibernate中,集合映射是将数据库中的表关系映射到对象的集合属性上,以便实现对象关系映射(ORM)。本文将深入探讨Hibernate中的四种主要集合映射类型:Set、List、Array和Map,以及它们在实际...

    Hibernate 映射类型与Java 类型对照

    Hibernate简化了Java应用程序与数据库之间的交互,它允许我们将Java对象直接映射到数据库中的表。理解Hibernate映射类型与Java类型的对应关系对于有效地使用Hibernate至关重要。 首先,我们来看一下基本数据类型的...

    springmvc+hibernate多表映射

    在这个“springmvc+hibernate多表映射”的主题中,我们将深入探讨如何在SpringMVC项目中集成Hibernate,并实现多表之间的关联映射。这通常涉及到实体类的设计、配置文件的设置以及数据库操作。 首先,SpringMVC是...

    hibernate的多种映射关系

    在 Hibernate 中,映射关系是将数据库表与 Java 类之间的关联方式,使得对象模型可以与关系模型无缝对接。本篇文章将详细探讨 Hibernate 中的多种映射关系。 1. **一对一映射 (One-to-One)** 一对一映射表示两个...

    hibernate bag 集合映射

    在Hibernate中,集合映射是指将数据库中的表与Java集合对象(如List、Set等)进行关联,方便对一组相关数据进行操作。 "bag"是Hibernate中的一种集合类型,表示无序的、可重复的对象集合。在数据库层面,这通常对应...

    Hibernate_容器映射技术笔记

    本篇笔记主要探讨了如何使用Hibernate进行容器映射,特别是针对集合类型的映射,如List、Set和Map。 首先,我们来看集合类型在Hibernate中的映射: 1. **单值Collection**: 这种情况通常指的是一个对象与多个其他...

    hibernate中容器映射技术

    通过Set、Map和List等不同类型的容器,我们可以根据实际需求选择最合适的映射方式,实现数据模型与数据库表之间的无缝对接。无论是对于简单的一对多关系,还是复杂的一对多、多对多关系,Hibernate的容器映射都能...

    Hibernate 关联关系映射分类

    Hibernate是一种持久层框架,主要用于Java应用程序中的对象关系映射(ORM),它能够将面向对象的数据模型转换为数据库中的关系型数据模型,从而简化了数据访问和操作的复杂性。 ### 一对一关联 一对一关联是数据库...

    Hibernate实体映射

    在Java世界中,Hibernate是一个非常流行的对象关系映射(ORM)框架,它简化了数据库操作,使得开发者可以使用面向对象的方式来处理数据。本资源“Hibernate实体映射”提供了一个深入理解这一关键概念的机会,通过...

    hibernate关联映射实例

    在Java企业级开发中,Hibernate是一个非常重要的对象关系映射(ORM)框架,它极大地简化了数据库操作。本文将深入探讨“hibernate关联映射实例”中的关键知识点,包括一对多、多对多和继承映射,这些都是Hibernate中...

Global site tag (gtag.js) - Google Analytics