<!-- XML
文件的声明
-->
<?
xml
version
=
"1.0"
encoding
=
"utf-8"
?>
<!-- hibernate DTD
文件的声明
-->
<!
DOCTYPE
hibernate-mapping
PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"
>
<!--
映射文件的根节点
-->
<
hibernate-mapping
>
<!--
对象关系映射的开始:
class
元素表示类和数据库中的表的映射关系。
name
属性指定持久化类(或者接口)的
Java
全限定名;
table
属性指定要映射的对应的数据库表名
-->
<
class
name
=
"org.qiujy.bean.User"
table
=
"user"
>
<!--
持久化类对象的对象标识符
(OID)
和表的主键的映射关联:
name
属性指定类中作为
OID
的属性名;
column
属性表中主键字段的名字;
type
属性指定
Hibernate
的映射类型
-->
<
id
name
=
"id"
column
=
"id"
type
=
"int"
>
<!--
指定对象标识符生成器:
class
属性指定生成器的类别名
-->
<
generator
class
=
"native"
/>
</
id
>
<!--
普通属性的映射:
name
属性:属性的名字
,
以小写字母开头;
column
属性:对应的数据库字段名
type
属性:
指定
Hibernate
的映射类型
-->
<
property
name
=
"name"
column
=
"name"
type
=
"string"
/>
<
property
name
=
"age"
column
=
"age"
type
=
"int"
/>
</
class
>
</
hibernate-mapping
>
|
Java
类型
|
Hibernate
映射类型
|
标准
SQL
类型
|
int
或
java.lang.Integer
|
integer
或
int
|
INTEGER
|
long
或
java.lang.Long
|
long
|
BIGINT
|
short
或
java.lang.Short
|
short
|
SMALLINT
|
byte
或
java.lang.Byte
|
byte
|
TINYINT
|
float
或
java.lang.Float
|
float
|
FLOAT
|
double
或
java.lang.Double
|
double
|
DOUBLE
|
java.math.BigDecimal
|
big_decimal
|
NUMERIC
|
char
或
java.lang.Character
|
character
|
CHAR(1)
|
java.lang.String
|
string
|
VARCHAR
|
boolean
或
java.lang.Boolean
|
boolean
|
BIT
|
boolean
或
java.lang.Boolean
|
yes_no
|
CHAR(1)('
Y
'
或
'
N
')
|
boolean
或
java.lang.Boolean
|
true_false
|
CHAR(1)('
T
'
或
'
F
')
|
Java
类型
|
Hibernate
映射类型
|
标准
SQL
类型
|
说明
|
java.util.Date
或
java.sql.Date
|
date
|
DATE
|
日期
|
java.util.Date
或
java.sql.Time
|
time
|
TIME
|
时间
|
java.util.Date
或
java.sql.Timestamp
|
timestamp
|
TIMESTAMP
|
时间戳
|
java.util.Calendar
|
calendar
|
TIMESTAMP
|
|
java.util.Calendar
|
calendar_date
|
DATE
|
|
Java
类型
|
Hibernate
映射类型
|
标准
SQL
类型
|
MySQL
类型
|
Oracle
类型
|
byte[]
|
binary
|
VARBINARY(
或者
BLOB)
|
BLOB
|
BLOB
|
java.lang.String
|
text
|
CLOB
|
TEXT
|
CLOB
|
实现
java.io.Serializable
接口的任意一个
java
类
|
serializable
|
VARBINARY(
或者
BLOB)
|
BLOB
|
BLOB
|
java.sql.Clob
|
clob
|
CLOB
|
TEXT
|
CLOB
|
java.sql.Blob
|
blob
|
BLOB
|
BLOB
|
BLOB
|
<
id
name
=
"id"
column
=
"id"
type
=
"int"
>
<
generator
class
=
"native"
/>
</
id
>
|
标识符生成器
|
描述
|
increment
:
|
由
hibernate自动以递增的方式生成标识符,每次增量为1.适用于代理
主键.
|
identity
:
|
由底层数据库生成标识符.数据库必须支持自动增长字段类型,不便于不同数据库之间的移植.适用于代理
主键.
|
sequence
:
|
Hibernate根据底层数据库序列来生成标识符.前提是条件是底层数据库支持序列(如Oracle).适用于代理
主键.
|
hilo
:
|
Hibernate根据high/how算法来生成标识符.适用于代理
主键.
|
seqhilo
:
|
使用一个高/低位算法来高效的生成
long ,
short 或者
int 类型的标识符,给定一个数据库序列(sequence)的名字.适用于代理
主键
.
|
native
:
|
根据底层数据库对自动生成标识符的支持能力,来选择identity
,sequence
或hilo
.适用于代理主键.
|
uuid.hex
:
|
Hibernate采用128位的UUID(Universal Unique Identification)算法来生成标识符.UUID算法能够在网络环境中生成唯一的字符串标识符.但字符串型的
主键比整型的
主键占用更多的数据库空间.适用于代理
主键.
|
uuid.string
:
|
使用UUID算法来生成标识符.UUID被编码为一个16个字符长的任意ASCII组成的字符串。适用于代理
主键.
|
assigned
:
|
由Java应用程序负责生成标识符,需在保存数据前完成.适用于自然
主键.
|
……
<
id
name
=
"no"
column
=
"no"
type
=
"int"
>
<!--
指定主键生成方式为
Assigned -->
<
generator
class
=
"assigned"
/>
</
id
>
……
|
……
<composite-
id>
<key-property
name
=
"firstName"
column
=
"firstname"
type
=
"string"
>
<
key-property
name
=
"lastName"
column
=
"lastname"
type
=
"string"
>
</composite-
id
>
……
|