`

hibernate数据类型与OR映射

阅读更多

1、Hibernate基本数据类型

Hibernate基本类型

JAVA类型

标准SQL字段类型

Boolean

Boolean,java.lang.boolean

BIT

Yes_no

Boolean,java.lang.boolean

Char(1)( Y / N )

True_false

Boolean,java.lang.boolean

Char(1)( Y / N )

Byte

Byte,java.lang.byte

TINYINT

Short

Short,java.lang.short

SMALLINT

Interger

Int,java.lang.integer

INTEGER

Long

Long,java.lang.long

BIGINT

Float

Float,java.lang.float

FLOAT

Double

Double,java.lang.Double

DOUBLE

Big_decimal

Java.math.BigDecimal

NUMBERIC

Character

Java.lang.string

CHAR(1)

String

Java.lang.string

VARCHAR

Date

Java.util.Date,java.sql.Date

DATE

Time

Java.util.Date,java.sql.Time

TIME

Timestamp

Java.util.Date,java.sql.TimeStamp

TIMESTAMP

Calender

Java.util.Calendar

TIMESTAMP

Calender_date

Java.util.Calendar

Date

Clob

Java.sql.clob

CLOB

Blob

Java.sql.blob

BLOB

Binary

Byte[]

VARBINARY,BLOB

Text

Java.lang.String

CLOB

Seralizable

Java.io.serializable

VARBINARY,BLOB

Class

Java.lang.class

VARCHAR

Local

Java.util.locale

VARCHAR

Timezone

Java.util.timezone

VARCHAR

Currency

Java.util.currency

VARCHAR

 

 

2、OR映射

(1)id映射

< id   column = "ID"   name = "id"   type = "java.lang.String" >

     < generator   class = "uuid.hex" />

</ id >

name:指定POJO类的成员变量名

type:name指定变量的数据类型

column:对应数据库表的主键字段

 

(2)表/类映射

< class   name = "test.pojo.company"   table = "company"   lazy = "false" >

</ class >

name:指定POJO类

table:POJO类对应的数据库表

lazy:延迟加载

 

 

 

 

(3)实体映射

< hibernate-mapping >

     < class   name = "test.pojo.company"   table = "company"   >

        < id   column = "ID"   name = "id"   type = "java.lang.String" >

            < generator   class = "uuid.hex" />

        </ id >

        < property   column = "NAME"   name = "name"   type = "java.lang.String" />

        < property   column = "ADDRESS"   name = "address"   type = "java.lang.String" />

     </ class >

</ hibernate-mapping >

 

(4)复合主键映射

< 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)

 

 

3、generator子元素,其class属性指定主键生成方式:

increment(递增) :用于为long, short或者int类型生成唯一标识。只有在没有其他进程往同一张表中插入数据时才能使用。 在集群下不要使用。

identity  :对DB2,MySQL, MS SQL Server, Sybase和HypersonicSQL的内置标识字段提供支持。返回的标识符是long, short 或者int类型的。

sequence (序列) :在DB2,PostgreSQL, Oracle, SAP DB, McKoi中使用序列(sequence),而在Interbase中使用生成器(generator)。返回的标识符是long, short或者 int类型的。

hilo (高低位) : 使用一个高/低位算法来高效的生成long, short或者 int类型的标识符。给定一个表和字段(默认分别是是hibernate_unique_key 和next_hi)作为高位值得来源。高/低位算法生成的标识符只在一个特定的数据库中是唯一的。在使用JTA获得的连接或者用户自行提供的连接中,不要使用这种生成器。

seqhilo(使用序列的高低位) :使用一个高/低位算法来高效的生成long, short或者 int类型的标识符,给定一个数据库序列(sequence)的名字。

uuid.hex   :用一个128-bit的UUID算法生成字符串类型的标识符。在一个网络中唯一(使用了IP地址)。UUID被编码为一个32位16进制数字的字符串。

uuid.string   :使用同样的UUID算法。UUID被编码为一个16个字符长的任意ASCII字符组成的字符串。不能使用在PostgreSQL数据库中

native(本地) :根据底层数据库的能力选择identity, sequence 或者hilo中的一个。

assigned(程序设置) :让应用程序在save()之前为对象分配一个标示符。

foreign(外部引用)

select :hibernate3中新增的。需要提供一个唯一的标识字段进行二次读取,以获取触发器生成的主键值,通过param子元素进行定义,比如:

< generator   class = "select" >

     < param   name = "key" > key_field </ param >

</ generator >

该方法主要针对遗留系统的改造工程,一些早期的系统主键依赖于触发器生成。当数据库insert时,触发器捕获这一操作,并为主键赋值,在插入数据库后,再次读取某一识别字段读取已经插入的数据,获取其主键值。

分享到:
评论

相关推荐

    Hibernate 中文API文档

    Hibernate不仅仅管理Java类到数据库表的映射(包括Java数据类型到SQL数据类型的映射),还提供数据查询和获取数据的方法,可以大幅度减少开发时人工使用SQL和JDBC处理数据的时间。 Hibernate的目标是对于开发者...

    hibernate 调用oracle函数

    Hibernate作为一个优秀的Java ORM(对象关系映射)框架,极大地简化了Java应用与数据库之间的交互。Oracle则作为一款强大的关系型数据库管理系统,广泛应用于企业级应用中。本文将深入探讨如何在Hibernate中调用...

    hibernate对象三状态及OneToOne&OneToMany&ManyToMany

    在Java世界中,Hibernate是一个非常流行的ORM(对象关系映射)框架,它简化了数据库操作,使得开发者可以使用面向对象的方式来处理数据。本篇将详细阐述Hibernate中的对象三状态、一对一(OneToOne)、一对多...

    Hibernate的高级查询

    在Java的持久化框架中,Hibernate是一个非常重要的工具,它为开发者提供了强大的对象关系映射(ORM)功能,使得在数据库操作上可以采用面向对象的方式。当我们需要进行更复杂的数据库查询时,Hibernate提供了丰富的...

    Hibernate框架文档

    1. **OR映射问题**:对象关系映射(ORM)是将面向对象的编程模型与关系数据库进行转换的关键技术。在Hibernate之前,解决ORM问题的方案如实体EJB(CMP方式)、JDO(Java Data Objects)以及TopLink等,但它们都有...

    Hibernate-HQL-查询-Query资料

    - HQL是Hibernate提供的面向对象的查询语言,与SQL类似,但更加面向对象,将数据库表映射为Java类,表中的行映射为类的对象。 - HQL与JPA的JPQL相似,都是为了提高代码的可读性和可维护性,避免硬编码SQL。 2. **...

    Struts2+hibernate实现登陆的案例

    Hibernate则是一个对象关系映射(ORM)框架,它简化了数据库操作,通过将Java类与数据库表映射,实现了面向对象编程与关系数据库之间的桥梁。在这个案例中,Hibernate使用了注解配置,这意味着我们不需要XML配置文件...

    hibernate查询

    【Hibernate查询】是一种在Java应用中使用ORM(对象关系映射)框架Hibernate进行数据库操作的方式。Hibernate通过HQL(Hibernate Query Language)和Criteria API提供了一种面向对象的查询机制,使得开发者无需直接...

    最经典的hibernate教程_从入门到精通4(hbiernate学习)

    Hibernate是一个流行的Java ORM(对象关系映射)框架,它允许开发者将数据库操作转换为面向对象的方式,从而简化了数据访问层的编程。在这个最经典的Hibernate教程的第四部分,我们将深入探讨Hibernate的查询机制。 ...

    spring_hibernate_annotation的三种实现

    Spring是一个全面的后端开发框架,提供依赖注入、AOP(面向切面编程)、MVC(模型-视图-控制器)等特性,而Hibernate则是一个强大的对象关系映射(ORM)工具,简化了Java应用与数据库之间的交互。当将两者结合使用并...

    Hibernate中Criteria的完整用法

    在Java的持久化框架Hibernate中,Criteria API提供了一种动态构造SQL查询的方式,它允许开发者在运行时构建查询,而无需硬编码HQL(Hibernate Query Language)或原生SQL语句。Criteria API提供了丰富的功能,包括但...

    Hibernate查询语言

    Hibernate是一个强大的Java对象关系映射(ORM)框架,它简化了在Java应用程序中操作数据库的过程。其中,Hibernate查询语言(HQL)是Hibernate提供的一种面向对象的查询语言,它允许开发者用类名和属性名来执行...

    spring3.2+strut2+hibernate4

    --此处hibernate 的映射采用的是.xml 配置则应设置为:class=”org.springframework.orm.hibernate3.LocalSessionFactoryBean”--&gt; &lt;property name="dataSource" ref="dataSource" /&gt; &lt;prop key="...

    NHibernate入门级学习实例

    User.hbm.xml.txt 文件是用户实体类的Hibernate映射文件。它是XML格式,定义了User类与数据库表之间的映射关系,包括字段对应、主键设置、关联关系等。理解映射文件是掌握NHibernate的关键,因为它规定了对象模型与...

    IBATIS入门

    与 Hibernate 和 Apache OJB 等全面的 ORM(对象关系映射)解决方案不同,IBATIS 提供了“半自动化”的 ORM 实现。这意味着开发者需要编写自己的 SQL 语句,而框架则负责将这些 SQL 与 Java 代码连接起来,提供了更...

    S2SH整合考勤小系统

    Hibernate支持通过`AND`、`OR`等逻辑运算符组合多个条件,可以使用`Restrictions`类或者在HQL(Hibernate Query Language)中直接编写查询语句。这使得我们可以构建出复杂的查询条件,满足多样化的检索需求。 再者...

    ibatis.doc

    在对象关系映射(OR映射)上,iBATIS允许开发者在XML映射文件中定义POJO(Plain Old Java Object)与数据库表之间的映射关系。这样,Java对象的属性可以直接映射到SQL语句的占位符,反之亦然。 iBATIS的高级特性...

    java面试题

    请你谈谈对Hibernate OR映射的理解? 答:将数据库中的每一张表都映射成一个实体。 配置了lazy="true"一定会懒加载吗? 答:不一定,如果在配置中你也使用了fetch属性的话此时lazy就会失效。 Hibernate数据库标识与...

    同学及自己面试题目(java面试准备).doc

    - Int是Java的基本数据类型,直接存储值,而Integer是Int的包装类,可以提供额外的功能,如自动装箱/拆箱、比较等。 9. **Hibernate的工作原理和优点**: - Hibernate通过读取配置文件和映射信息建立...

    《计算机程序设计员JAVA》(三级)定义.pdf

    Hibernate的内容包括持久化概念、JDO架构、Hibernate概念、Hibernate中Session内的方法组成、Hibernate OR映射、Hibernate二级缓存等。 AJAX的内容包括AJAX的概念、AJAX的构成、XmlHttprequest的使用等。 本文档对...

Global site tag (gtag.js) - Google Analytics