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时,触发器捕获这一操作,并为主键赋值,在插入数据库后,再次读取某一识别字段读取已经插入的数据,获取其主键值。
分享到:
相关推荐
在描述中提到的`org.hibernate.PropertyValueException: not-null property references a null or transient value`是Hibernate抛出的一个常见异常,表示尝试保存一个实体时,其某个非空属性为null或未持久化。...
Hibernate不仅仅管理Java类到数据库表的映射(包括Java数据类型到SQL数据类型的映射),还提供数据查询和获取数据的方法,可以大幅度减少开发时人工使用SQL和JDBC处理数据的时间。 Hibernate的目标是对于开发者...
Hibernate作为一个优秀的Java ORM(对象关系映射)框架,极大地简化了Java应用与数据库之间的交互。Oracle则作为一款强大的关系型数据库管理系统,广泛应用于企业级应用中。本文将深入探讨如何在Hibernate中调用...
在Java世界中,Hibernate是一个非常流行的ORM(对象关系映射)框架,它简化了数据库操作,使得开发者可以使用面向对象的方式来处理数据。本篇将详细阐述Hibernate中的对象三状态、一对一(OneToOne)、一对多...
1. **OR映射问题**:对象关系映射(ORM)是将面向对象的编程模型与关系数据库进行转换的关键技术。在Hibernate之前,解决ORM问题的方案如实体EJB(CMP方式)、JDO(Java Data Objects)以及TopLink等,但它们都有...
在Java的持久化框架中,Hibernate是一个非常重要的工具,它为开发者提供了强大的对象关系映射(ORM)功能,使得在数据库操作上可以采用面向对象的方式。当我们需要进行更复杂的数据库查询时,Hibernate提供了丰富的...
- HQL是Hibernate提供的面向对象的查询语言,与SQL类似,但更加面向对象,将数据库表映射为Java类,表中的行映射为类的对象。 - HQL与JPA的JPQL相似,都是为了提高代码的可读性和可维护性,避免硬编码SQL。 2. **...
Hibernate则是一个对象关系映射(ORM)框架,它简化了数据库操作,通过将Java类与数据库表映射,实现了面向对象编程与关系数据库之间的桥梁。在这个案例中,Hibernate使用了注解配置,这意味着我们不需要XML配置文件...
通过上述对几个常见 Hibernate 错误的解析及解决方法的介绍,我们可以发现大部分问题都与配置文件的设置、实体类的定义以及事务管理有关。在日常开发中,我们应该注意这些细节,以避免不必要的错误发生。同时,对于...
【Hibernate查询】是一种在Java应用中使用ORM(对象关系映射)框架Hibernate进行数据库操作的方式。Hibernate通过HQL(Hibernate Query Language)和Criteria API提供了一种面向对象的查询机制,使得开发者无需直接...
2. **配置Hibernate实体类**:为学生表创建对应的Hibernate实体类,并确保实体类与数据库表的映射关系正确。 3. **编写Java代码调用存储过程**: - 使用`Session`对象获取`StoredProcedureQuery`实例。 - 设置...
在Hibernate中,查询是获取数据的核心功能。以下是对几种查询方法的详细解释: 1. `get()` 和 `load()`:两者都用于根据ID获取对象,但有关键区别。`get()` 直接从数据库中获取数据,如果不存在则返回`null`;而`...
- **对象关系映射(ORM)**:Hibernate通过ORM技术将Java对象与数据库表建立映射关系,使得开发人员可以直接操作Java对象,而不需要关心底层的SQL语句。 - **缓存机制**:Hibernate提供了二级缓存机制,可以显著提高...
通过原生 SQL 查询数据,这里将 SQL 查询的结果映射到 `Student` 类型上。 #### 六、总结 本文详细介绍了 Hibernate Criteria API 的使用方法,包括基本概念、创建查询实例、添加查询条件以及示例代码分析。通过 ...
综上所述,Hibernate的Criteria API提供了一种灵活、类型安全的方式来构造查询,它可以适应多种查询需求,同时也能够与HQL和原生SQL查询结合使用,从而满足开发者的不同需求。掌握Criteria API的使用,对于提高在...
Hibernate是一个流行的Java ORM(对象关系映射)框架,它允许开发者将数据库操作转换为面向对象的方式,从而简化了数据访问层的编程。在这个最经典的Hibernate教程的第四部分,我们将深入探讨Hibernate的查询机制。 ...
Spring是一个全面的后端开发框架,提供依赖注入、AOP(面向切面编程)、MVC(模型-视图-控制器)等特性,而Hibernate则是一个强大的对象关系映射(ORM)工具,简化了Java应用与数据库之间的交互。当将两者结合使用并...
Hibernate是一个强大的Java对象关系映射(ORM)框架,它简化了在Java应用程序中操作数据库的过程。其中,Hibernate查询语言(HQL)是Hibernate提供的一种面向对象的查询语言,它允许开发者用类名和属性名来执行...