重新认识你认识的Hibernate(二)

Hibernate估计大家已经用过很多年了吧,好多同学说用过Hibernate,不需要你来讲,但再仔细想想,你能告诉我Hibernate是什么吗?

今天带大家重新认识一下你认识的Hibernate。

Hibernate 概述:持久化对象的生命周期

Transient Objects:使用new 操作符初始化的对象不是立刻就持久的。它们的状态是瞬时的,也就是说它们没有任何跟数据库表相关联的行为,只要应用不再引用这些对象(不再被任何其它对象所引用),它们的状态将会丢失,并由垃圾回收机制回收。

Persist Objects:持久实例是任何具有数据库标识的实例。它有持久化管理器Session统一管理,持久实例是在事务中进行操作的——它们的状态在事务结束时同数据库进行同步。当事务提交时,通过执行SQL的INSERT、UPDATE和DELETE语句把内存中的状态同步到数据库中。

Detached Objects:Session关闭之后,持久化对象就变为detached对象。表示这个对象不能再与数据库保持同步,它们不再受Hibernate管理。

Hibernate 概述:Hibernate基本数据类型

Hibernate 概述:Hibernate大对象数据类型

在java中,java.lang.String可以用来表示长字符串(长度超过255),字节数组byte[]可以用来存放图片或文件的二进制数据。此外在JDBCAPI中还提供了java.sql.Clob和java.sql.Blob类型,分别和标准SQL的CLOB和BLOB类型相对应。CLOB表示字符串大对象(CharacterLarger Object),BLOB表示二进制大对象(BinaryLarger Object)

Hibernate 概述:Hibernate主键策略

Hibernate主键的映射<id>标签的DTD文档如下

<!ELEMENTid (meta*, column*, generator?)>

<!ATTLISTid

name CDATA #IMPLIED

node CDATA #IMPLIED

access CDATA #IMPLIED

column CDATA #IMPLIED

type CDATA #IMPLIED

length CDATA #IMPLIED >

典型的主键映射代码如下

<id name="id" column="t_id"type="integer">

<generatorclass="identity" />

</id>

Hibernate对主键的管理分为三大类

1.Hibernate对主键id赋值

2.应用程序自己对主键id赋值

3.由数据库对主键id赋值

Hibernate 概述:Hibernate主键策略

<id>标签的可选元素<generator>子元素是一个java类的名字,用来为该持久化类的实例生成唯一的标识,所有的生成器都实现org.hibernate.id.IdentifierGenerator接口。Hibernate提供了很多内置的实现类。

1.assigned:主键由外部程序负责生成,无需Hibernate参与,主键由应用逻辑产生,实体对象再保存之前,必须显式的设置OID,主键的产生无需Hibernate的干预

<generatorclass="assigned"/>

2.Increment:hibernate将按照递增的方式设定主键,具体的方式是

先获取当前记录主键的最大值,然后再将该值加1作为主键。

<generator/>

3.Identity:表示数据库的主键生成方式为采用数据库的主键生成机制,例如SQLServer或MySQL的自动主键生成机制。

<generator/>

4.Sequence:这种方式针对由序列方式产生主键的数据库,例如Oracle。在<generator>的子元素<param name=“sequence”>指定用作产生主键的序列名称。

<id name="id" column="t_id"type="integer">

<generatorclass="sequence">

<paramname="sequence">H_SOME_SEQUENCE</param>

</generator>

</id>

5.Native:意味着将主键的生成机制交由Hibernate决定,Hibernate会根据配置文件中的方言(Dialect)定义,采用不同的数据库特定的主键生成方式。这是我们最常使用的方式

<generatorclass="native"> <paramname="sequence">H_SOME_SEQUENCE</param> </generator>

声明:本文章属于个人原创,转载请注明文章出处。

原文发布于微信公众号 - 全华班(quanhuaban)

原文发表时间:2018-03-05

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏吴生的专栏

MySQL Optimization 优化原理

如果能在头脑中构建一幅MySQL各组件之间如何协同工作的架构图,有助于深入理解MySQL服务器。下图展示了MySQL的逻辑架构图。

41115
来自专栏IT技术精选文摘

MySQL优化原理学习

说起MySQL的查询优化,相信大家收藏了一堆奇技淫巧:不能使用SELECT *、不使用NULL字段、合理创建索引、为字段选择合适的数据类型….. 你是否真的理解...

2105
来自专栏Linyb极客之路

MySQL优化原理

如果能在头脑中构建一幅MySQL各组件之间如何协同工作的架构图,有助于深入理解MySQL服务器。下图展示了MySQL的逻辑架构图。

1104
来自专栏张善友的专栏

Active Record和Domain Object + Dao

Martin Fowler的 Active Record pattern实现,它是指一个既包含数据又包含行为的对象,这些数据需要持久保存到对应的数据表中。...

1769
来自专栏JAVA高级架构

万字总结:学习MySQL优化原理,这一篇就够了!

说起MySQL的查询优化,相信大家收藏了一堆奇技淫巧:不能使用SELECT *、不使用NULL字段、合理创建索引、为字段选择合适的数据类型..... 你是否真的...

3697
来自专栏IT技术精选文摘

从程序员的角度深入理解MySQL

数据库基本原理 ? 第一,数据库的组成:存储 + 实例 不必多说,数据当然需要存储;存储了还不够,显然需要提供程序对存储的操作进行封装,对外提供增删改查的API...

1595
来自专栏JAVA同学会

MySql分页查询慢|这里告诉你答案

我们在开发的过程中使用分页是不可避免的,通常情况下我们的做法是使用limit加偏移量:

23511
来自专栏java达人

MySQL 加锁处理分析

背景 MySQL/InnoDB的加锁分析,一直是一个比较困难的话题。我在工作过程中,经常会有同事咨询这方面的问题。同时,微博上也经常会收到MySQL锁相关的私信...

1785
来自专栏性能与架构

HBase 的表结构

HBase 是一个NoSQL数据库,用于处理海量数据,可以支持10亿行百万列的大表,下面就了解一下数据是如何存放在HBase表中的 关系型数据库的表结构 为了更...

32113
来自专栏程序你好

MySQL数据优化总结-查询备忘录

1062

扫描关注云+社区