[转]Hibernate映射的基本操作
|
<!-- 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>
……
|
[转]Hibernate映射的基本操作的更多相关文章
- hibernate映射文件
Hibernate的持久化类和关系数据库之间的映射通常是用一个XML文档来定义的.该文档通过一系列XML元素的配置,来将持久化类与数据库表之间建立起一一映射.这意味着映射文档是按照持久化类的定义来创建 ...
- Hibernate映射文件如何配置触发器
Hibernate映射文件之触发器生成(generated属性.database-object元素) (2013-02-27 12:28:49) 转载▼ 标签: it 分类: JAVA学习笔记 这里分 ...
- Spring集成Hibernate映射文件的4种方式
概要: 在Spring的applicationContext.xml中集成Hibernate映射文件,通常是在<sessionFactory>这个Bean实例中进行的,若配置的映射文件较少 ...
- hibernate映射的 关联关系:有 一对多关联关系,一对一关联关系,多对多关联关系,继承关系
hibernate环境配置:导包.... 单向n-1:单向 n-1 关联只需从 n 的一端可以访问 1 的一端 <many-to-one> 元素来映射组成关系: name: 设定待映射的持 ...
- Hibernate注解映射sequence时出现无序增长问题+hibernate 映射 oracle ID自动增长:
Hibernate注解映射sequence时出现无序增长问题+hibernate 映射 oracle ID自动增长: 通过Hibernate注解的方式映射oracel数据库的sequence主键生成器 ...
- oracle ORA-01747(系统保留关键字)user.table.column, table.column 或列说明无效 hibernate映射oracle保留关键字
1.查询系统关键 select * from v$reserved_words 确认你使用的是否为关键字: select * from v$reserved_words w where w.KEYWO ...
- Hibernate映射类型对照表
Hibernate映射类型对照表 java类型 Hibernate映射类型 SQL类型 java.math.BigDecimal big_decimal numeric byte[] binary ...
- 02.Hibernate映射基础
前言:Hibernate的核心功能是根据数据库到实体类的映射,自动从数据库绑定数据到实体类.使我们操作实体类(Java对象)就能对数据库进行增.删.查.改,而不用调用JDBC API使数据操作变得简单 ...
- hibernate Java 时间和日期类型的 Hibernate 映射
基础知识: 在 Java 中, 代表时间和日期的类型包含: java.util.Date 和 java.util.Calendar. 此外, 在 JDBC API 中还提供了 3 个扩展了 java. ...
随机推荐
- transition Css3过度详解
过度语法: .example { transition-property: background-color; //需要过度的css属性 transition-duration: 2s; //过度所需 ...
- 文成小盆友python-num11-(1) 线程 进程 协程
本节主要内容 线程补充 进程 协程 一.线程补充 1.两种使用方法 这里主要涉及两种使用方法,一种为直接使用,一种为定义自己的类然后继承使用如下: 直接使用如下: import threading d ...
- Factorial Solved Problem code: FCTRL
import sys #import psyco #很奇怪,这题用psyco就runtime error #psyco.full() def z(n): #这个应该是技巧的一种算法 r = 0 whi ...
- 二维指针*(void **)的研究(uC/OS-II案例) 《转载》
uC/OS-II内存管理函数内最难理解的部分就是二维指针,本文以图文并茂的方式对二维指针进行了详细分析与讲解.看完本文,相信对C里面指针的概念又会有进一步的认识. 一.OSMemCreate( ) 函 ...
- uc/os 笔记(转)
1.uC/OS-II中使用互斥信号对象应该注意 互斥信号对象(Mutual Exclusion Semaphore)简称Mutex,是uC/OS-II的内核对象之一,用于管理那些需要独占访问的资源,并 ...
- sql基础复习
--.while循环 declare @sum int declare @i int ) begin set @sum =@sum+@i ) print @i end print @sum --.go ...
- Ubuntu12.04下载Android4.0.1源码全过程,附若干问题解决[转]
学校里一直在做应用层开发,考虑到日后就业问题,这次决定研究源码和驱动,并进行编译.没想到就下载源码这一步折腾了我整整两天,期间遇到很多问题,哎,记录于此,希望日后再下源码的人不要再走无谓的弯路了.事实 ...
- Qt编程之qrc文件的链接
在Qt里面,.qrc文件是一种类似XML结构的文件,用结构化数据描述应用程序所需要的资源位置,例如图片,应用程序的图标文件等.它最终是与.ui文件类似都被通过Qt提供的命令行工具生成对应的qrc_XX ...
- 2014.7.8模拟赛【笨笨当粉刷匠】|bzoj1296 [SCOI]粉刷匠
笨笨太好玩了,农田荒芜了,彩奖用光了,笨笨只好到处找工作,笨笨找到了一份粉刷匠的工作.笨笨有n条木板需要被粉刷.每条木板被分成m个格子,每个格子要被刷成红色或蓝色.笨笨每次粉刷,只能选择一条木板上一段 ...
- 按每k个结点反转链表
//按每k个结点反转链表 Node* turn_k(Node* head,int n,int k) { Node* p=head; ;t<k;t++) p=p->next; //为了获取最 ...