文档章节

Hibernate<三>-ORM映射:单表映射

Mr_ET
 Mr_ET
发布于 2017/08/17 15:27
字数 2572
阅读 12
收藏 1
点赞 0
评论 0

 

1    映射关系总览
    ①单类→单表
    ②单向n对1
    ③双向1对n
    ④1对1基于外键
    ⑤1对1基于主键
    ⑥单向多对多
    ⑦双向多对多

2    单类→单表的映射
    ①映射主键
    ②映射日期类型
    ③映射大对象
    ④hbm文件中的其他属性
    ⑤数据类型映射对照表

3    Hibernate中主键生成方式
3.1    increment
    ①由Hibernate以递增的方式为代理主键赋值
    ②Hibernate会先读取数据库表中的主键的最大值,插入记录时以最大值+1作为主键
    ③不依赖底层数据库系统,所以适合各种类型的数据库
    ④在多线程模式下运行时,很容易发生错误(多个线程可能获取数据库表中的主键的最大值相同,都以最大值+1作为主键向数据库表中插入记录,导致插入到数据库表中的多条记录的主键相同,从而违反了数据库表中主键的唯一性,故会报错)
    ⑤OID必须为long、int或short类型,如果为byte则会抛出异常
3.2    hilo
    ①由Hibernate根据high/low算法生成主键
    ②hilo标识符生成器在生成标识符时,需要读取并修改HI_TABLE表中的NEXT_VALUE值
    ③完全不依赖于任何数据库系统
    ④OID必须为long、int或short类型,如果为byte则会抛出异常

<generator class= "hilo">
   <param name= "table">HL_table </param>
   <param name= "column">NEXT_VALUE </param>
   <param name= "max_lo">10</param >
</generator>


    ⑤高低算法

参见:我写的博客:Hibernate - 高低算法

3.3    identity
    ①由具体数据库负责生成主键
    ②要求数据库将主键定义为自动增长类型
    ③支持自增主键的数据库:MySQL、DB2、微软SQLServer、Sybase等;
但是有局限性,因为Oracle不支持;
    ④OID必须为long、int或short类型,如果为byte则会抛出异常

3.4    sequence
    ①利用底层的数据库提供的序列生成标识符
    ②要求底层数据库支持序列:DB2、Oracle
    ③OID必须为long、int或short类型,如果为byte则会抛出异常
    ④配置方式

<id name ="studentId" type="java.lang.Integer">
    <column name ="STUDENTID" />
    <generator class ="sequence">
        <param name ="sequence">stu_seq</ param>
    </generator >
</id >

3.5    native
    ①依据底层数据库对自动生成标识符的支持能力,来选择使用identity、sequence或hilo
    ②由于native标识符生成器能够根据底层数据库系统的类型,自动选择合适的方式生成主键,所以非常适合跨数据库平台开发
    ③OID必须为long、int或short类型,如果为byte则会抛出异常

3.6    assigned(指定的)
    Hibernate和数据库都不负责生成主键的值,完全由程序员自己指定。
3.7    其他主键生成方式
    select、seqhilo、foreign、guid等等
4    在Hibernate中映射日期和时间
4.1    Java数据类型和JDBC API的对应关系

    注:时间戳:从1970年1月1日0点0时0分0秒开始计时,到当前时间所经过的毫秒数

4.2    Hibernate中的日期映射方式

    大部分情况下Hibernate可以根据Java类型自动找到对应的Hibernate映射类型,从而确定数据库表中的字段类型,但如果一个Java类型对应的Hibernate映射类型不只一个,那么就必须为Java类型明确指定Hibernate映射类型,例如:

5    Java中大对象类型的Hibernate映射
5.1    大对象
    ①长字符串:长度超过255的字符串
    ②二进制数据:图片、音频、视频等文件

5.2    Java中的大对象类型
    ①长字符串
        [1]java.lang.String[推荐]
        [2]java.sql.Clob——Character Large Object,对应SQL标准类型中的CLOB
    ②二进制数据
        [1]java.sql.Blob——Binary Large Object,对应SQL标准类型中的BLOB(推荐)
        [2]byte[]
5.3    MySQL不支持标准SQL的CLOB类型
    ①TEXT
    ②MEDIUMTEXT
    ③LONGTEXT

5.4    精确映射SQL类型
    ①使用Hibernate映射大对象

<property name= "content" type ="text"/>在MySQL中生成的字段类型:longtext
<property name= "photo" type ="blob"/>在MySQL中生成的字段类型:longblob

    ②精确指定SQL类型

<property name= "content" type ="text">
     <column name ="my_content" sql-type="mediumtext" />
</property>
<property name= "photo" type ="blob">
     <column name ="my_photo" sql-type="mediumblob" />
</property>

5.5    使用Hibernate工具类创建大对象

FileInputStream in = new FileInputStream( "chain.jpg");
Blob photo = Hibernate.getLobCreator(session ).createBlob(in, in.available());

5.6    通过大对象获取输入流

InputStream in = photo.getBinaryStream();
OutputStream out = new FileOutputStream( "bingbing.jpg");
byte [] b = new byte[1024];
int len = 0;
while((len = in.read(b)) != -1){
   out.write(b, 0, len);
}
in.close();
out.close();

    附:MySQL中四种BLOB类型的最大范围

6    Hibernate映射类型对照表

7    对象关系映射文件
7.1    Hibernate使用*.hbm.xml文件定义持久化类和数据库表之间的映射关系,并以这个文件为依据生成各种SQL语句
7.2    映射关系
    ①持久化类:数据库表
    ②持久化类属性:数据库表中的字段
7.3    常用设置

7.4    元素属性说明

元素 属性 说明
hibernate-mapping schema 指定所映射的数据库schema的名称。若指定该属性,则表明会自动添加该 schema前缀
catalog 指定所映射的数据库catalog的名称
default-cascade 默认值为none。设置hibernate默认的级联风格。若配置Java属性,集合映射时没有指定cascade属性,则Hibernate 将采用此处指定的级联风格
default-access 默认为property。指定Hibernate的默认的属性访问策略。默认值为property,即使用getter,setter方法来访问属性。若指定access,则Hibernate会忽略getter/setter方法,而通过反射直接访问成员变量。
default-lazy 默认值为true。设置Hibernat的延迟加载策略。该属性的默认值为true,即启用延迟加载策略。若配置Java属性映射,集合映射时没有指定lazy属性,则Hibernate将依据这一设定使用延迟加载策略
auto-import 默认值为true。指定是否可以在查询语言中使用非全限定的类名(仅限于本映射文件中的类)。 
package 指定一个包前缀,如果在映射文档中没有指定全限定的类名,就使用这个作为包名。
class name 指定该持久化类映射的持久化类的类名
table 指定该持久化类映射的表名,Hibernate默认以持久化类的类名作为表名
dynamic-insert 若设置为true,表示当保存一个对象时,会动态生成insert语句,insert语句中仅包含所有取值不为null的字段。默认值为false。
dynamic-update 若设置为true,表示当更新一个对象时,会动态生成update语句,update语句中仅包含所有取值需要更新的字段。默认值为false
select-before-update 设置Hibernate在更新某个持久化对象之前是否需要先执行一次查询。默认值为false
batch-size 指定根据OID来抓取实例时每批抓取的实例数
lazy 指定是否使用延迟加载
mutable 若设置为true,等价于所有的<property>元素的update属性为 false,表示整个实例不能被更新。默认为true。
discriminator-value 指定区分不同子类的值。当使用<subclass/>元素来定义持久化类的继承关系时需要使用该属性
id name 标识持久化类OID的属性名
column 设置标识属性所映射的数据表的列名(主键字段的名字)
unsaved-value 若设定了该属性,Hibernate会通过比较持久化类的OID值和该属性值来区分当前持久化类的对象是否为临时对象
type 指定Hibernate映射类型。Hibernate映射类型是Java类型与SQL类型的桥梁。如果没有为某个属性显式设定映射类型,Hibernate会运用反射机制先识别出持久化类的特定属性的Java类型,然后自动使用与之对应的默认的Hibernate映射类型。Java的基本数据类型和包装类型对应相同的Hibernate映射类型。基本数据类型无法表达null,所以对于持久化类的OID推荐使用包装类型。
generator class 标识符生成器全类名或简单类名
property name 指定该持久化类的属性的名字
column 指定与类的属性映射的表的字段名。如果没有设置该属性,Hibernate将直接使用类的属性名作为字段名
type 指定Hibernate映射类型。Hibernate映射类型是Java类型与SQL类型的桥梁。如果没有为某个属性显式设定映射类型,Hibernate会运用反射机制先识别出持久化类的特定属性的Java类型,然后自动使用与之对应的默认的Hibernate映射类型
not-null 若该属性值为true,表明不允许为null,默认为false——?
access 指定Hibernate的默认的属性访问策略。默认值为property,即使用getter/setter方法来访问属性。若指定field,则Hibernate会忽略getter/setter方法,而通过反射访问成员变量
unique 设置是否为该属性所映射的数据列添加唯一约束
index 指定一个字符串的索引名称。当系统需要Hibernate自动建表时,用于为该属性所映射的数据列创建索引,从而加快该数据列的查询。
length 指定该属性所映射数据列的字段的长度
scale 指定该属性所映射数据列的小数位数,对double,float,decimal等类型的数据列有效
formula 设置一个SQL表达式,Hibernate将根据它来计算出派生属性的值

8    派生属性
    ①概念:并不是持久化类的所有属性都直接和表的字段匹配。持久化类的有些属性的值必须在运行时通过计算才能得出来,这种属性称为派生属性。
    ②formula属性
    [1]formula=“(sql)”的英文括号不能少
    [2]SQL表达式中的列名和表名都应该和数据库对应,而不是和持久化对象的属性对应
    [3]如果需要在formula属性中使用参数,可直接使用where cur.id=id 形式,其中id就是参数,和当前持久化对象的id属性对应的列的id值将作为参数传入

 

GitHub地址:https://github.com/leebingbin/  

 

 

© 著作权归作者所有

共有 人打赏支持
Mr_ET
粉丝 29
博文 90
码字总数 124020
作品 0
朝阳
高级程序员
Hibernate入门

Hibernate简介 Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一个全自动的ORM框架,hibernate可以自动生成SQL语句...

iborder
2016/10/31
34
0
4.1 Hibernate概述

Hibernate是一个开源的对象关系映射框架,它对JDBC进行了轻量级的封装(未完全封装),使程序员可以使用面向对象的编程思想来操纵数据库。Hibernate是一个对象/关系映射的解决方法,简单的说...

JerryPan
2016/02/26
182
0
【持久化框架】Mybatis与Hibernate的详细对比

前言 这篇博文我们重点分析一下Mybatis与Hibernate的区别,当然在前面的博文中我们已经深入的研究了Mybatis和Hibernate的原理。 Mybatis 【持久化框架】Mybatis简介与原理 【持久化框架】Spr...

sietai
05/18
0
0
【原创】再谈基于注解运行时动态ORM映射

上一篇贴出《基于注解运行时动态ORM映射》的方案,到底哪些地方需要用?又该怎么用呢?!我想你会有这样的疑问,其实不瞒你说,我也有!呵呵~ 再谈一把,就成为“必须的”~ 因此,本文主要介绍...

andy_zheng
2012/11/13
0
8
数据映射组件NewLife.XCode优势

数据映射组件XCode优势 XCode是一个超越了ORM范围的映射组件,除了对象到关系数据库的映射外,还有到网络和其它二进制形式等的映射,所以称之为数据映射组件。 相对于国内外其它ORM,XCode具...

长征6号
2016/11/27
0
0
图形化Hibernate框架理解

基于Hibernate框架原理的图形化理解示意图: 图解Hibernate说明: 在Hibernate工作的原理中,它是通过利用数据库以其他的配置如Hibernate.propertie、XML.mapping等来为应用程序(Applicati...

鲁雯雪
2013/12/27
0
0
【Java框架】 Hibernate与Mybatis对比

Hibernate与Mybatis对比 今天同事跟我说现在的小规模公司很少用hibernate,大部分都用mybatis。平时也经常接触这两方面,正好最近不怎么忙,查看网上其他相关技术文档 ,梳理下Mybatis和Hib...

林元煌
2017/07/05
0
0
JAVA持久层框架的概述(ibatis>>mybatis)

现在主流的ORM映射框架有Hibernate、Apache OJB;这些基于Java的持久层框架都提供了全自动的对象–关系映射机制,能很好的实现从对象到关系数据的持久化操作。几乎不需要写任何的SQL语句(根据...

battier
2011/06/21
0
2
Java专家之路(二)---数据访问和数据持久化框架的总结

Java数据访问和持久化(SQL) 方案一:JDBC 什么是JDBC? Java语言访问数据库的一种规范,是一套API。JDBC (Java Database Connectivity) API,即Java数据库编程接口,是一组标准的Java语言中的...

u011500356
2017/12/20
0
0
Hibernate基本映射(三)

这篇博客小编介绍Hibernate的经典内容:对象关系映射。主要介绍映射的基本概念,映射的分类,映射文件。 概念 ORM(Object Relational Mapping),即对象关系映射。它的作用就是在关系型数据...

architect刘源源
01/11
3
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

SpringBoot | 第十章:Swagger2的集成和使用

前言 前一章节介绍了mybatisPlus的集成和简单使用,本章节开始接着上一章节的用户表,进行Swagger2的集成。现在都奉行前后端分离开发和微服务大行其道,分微服务及前后端分离后,前后端开发的...

oKong
今天
5
0
Python 最小二乘法 拟合 二次曲线

Python 二次拟合 随机生成数据,并且加上噪声干扰 构造需要拟合的函数形式,使用最小二乘法进行拟合 输出拟合后的参数 将拟合后的函数与原始数据绘图后进行对比 import numpy as npimport...

阿豪boy
今天
1
0
云拿 无人便利店

附近(上海市-航南路)开了家无人便利店.特意进去体验了一下.下面把自己看到的跟大家分享下. 经得现场工作人员同意后拍了几张照片.从外面看是这样.店门口的指导里强调:不要一次扫码多个人进入....

周翔
昨天
1
0
Java设计模式学习之工厂模式

在Java(或者叫做面向对象语言)的世界中,工厂模式被广泛应用于项目中,也许你并没有听说过,不过也许你已经在使用了。 简单来说,工厂模式的出现源于增加程序序的可扩展性,降低耦合度。之...

路小磊
昨天
165
1
npm profile 新功能介绍

转载地址 npm profile 新功能介绍 npm新版本新推来一个功能,npm profile,这个可以更改自己简介信息的命令,以后可以不用去登录网站来修改自己的简介了 具体的这个功能的支持大概是在6这个版...

durban
昨天
1
0
Serial2Ethernet Bi-redirection

Serial Tool Serial Tool is a utility for developing serial communications, custom protocols or device testing. You can set up bytes to send accordingly to your protocol and save......

zungyiu
昨天
1
0
python里求解物理学上的双弹簧质能系统

物理的模型如下: 在这个系统里有两个物体,它们的质量分别是m1和m2,被两个弹簧连接在一起,伸缩系统为k1和k2,左端固定。假定没有外力时,两个弹簧的长度为L1和L2。 由于两物体有重力,那么...

wangxuwei
昨天
0
0
apolloxlua 介绍

##项目介绍 apolloxlua 目前支持javascript到lua的翻译。可以在openresty和luajit里使用。这个工具分为两种模式, 一种是web模式,可以通过网页使用。另外一种是tool模式, 通常作为大规模翻...

钟元OSS
昨天
2
0
Mybatis入门

简介: 定义:Mybatis是一个支持普通SQL查询、存储过程和高级映射的持久层框架。 途径:MyBatis通过XML文件或者注解的形式配置映射,实现数据库查询。 特性:动态SQL语句。 文件结构:Mybat...

霍淇滨
昨天
2
0
开发技术瓶颈期,如何突破

前言 读书、学习的那些事情,以前我也陆续叨叨了不少,但总觉得 “学习方法” 就是一个永远在路上的话题。个人的能力、经验积累与习惯方法不尽相同,而且一篇文章甚至一本书都很难将学习方法...

_小迷糊
昨天
1
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部