我们从几个方面进行阐述Hibernate

When? What ?

How?

When?

Hibernate由来是因为当时EJBBean1.1在处理entittBean架构时,花费的时间要比业务逻辑很多其它并且限制也太多。

Gavin King。一个充满激情,脾气倔强。不言败的人,在2001花费了两年时间,开发出了称为全世界流行的O/R Mapping的

工具。

What?

了解了历史,再看看Hibernate是什么?

Hibernate是一个对象关系映射(ORM框架,它对JDBC进行了很轻量级的对象封装,使得能够使用对象编程思维

来操纵数据库。看到这里应该了解到Hibernate也是一个持久层框架。

 ORM的简单规则:

类跟表相应

类属性与表字段相应

类实例与表中详细一条记录相应

一个类可与多个表相应,一个表也可相应多个类

DB中表与表之间的关系(如:外键)映射成为Object之间的关系

How?

Hibernate都给我们做了哪些,怎样体现它的长处

Hibernate有6大接口

Session、SessionFactory、Transaction、Query、Criteria和Configuration

接口间关系

(图片引自http://blog.csdn.net/jiuqiyuliang/article/details/39078749

自上而下的调用

1Configuration接口:负责配置并启动Hibernate,创建SessionFactory对象。

在Hibernate的启动的过程中,Configuration类的实例首先定位映射文档位置、读取配置,然后创建SessionFactory对象。

2SessionFactroy接口:负责初始化Hibernate。它充当数据存储源的代理,并负责创建Session对象。

  • 它是线程安全的,这意味着它的同一个实例能够被应用的多个线程共享。

  • 它是重量级的,这意味着不能任意创建或销毁它的实例。假设应用仅仅訪问一个数据库,仅仅须要创建一个SessionFactory实例

3Session接口:负责运行被持久化对象的CRUD操作(CRUD:增读更删)。

但须要注意的是Session对象是非线程安全的。因此在设计软件架构的时候,应该避免多个线程共享一个Session实例。同一时候,Hibernate的session不同于JSP应用中的HttpSession。

4Query和Criteria接口:Query和Criteria接口负责运行各种数据库查询。它能够使用HQL语言或SQL语句两种表达方式。

5Transaction接口:是Hibernate的数据库的数据库事务接口,它对底层的事务接口做了封装。

底层事务接口包含:

  • 1.jdbc  API
  • 2.JTA(JAVA Transation API)
  • 3.CORBA(Common Object Request Broker Architecture) API

不论什么事物都有两面,Hibernate也不例外

Hibernate长处:

  • 使用简单介绍的hql语句,如插入数据:原来的做法是:insert into 表名称 alue(值1。值2。值3,……),而如今的做法是:save(对象)。
  • 简化了DAO层编码工作。使开发更对象化了
  • 移植性好,支持各种数据库,假设换个数据库仅仅要在配置文件里变换配置就能够了,不用改变hibernate代码
  • 支持透明持久化。透明是针对上层而言的

Hibernate缺点:

  • 若是大量数据批量操作。则不适合使用Hibernate。
  • 复杂表操作就Over了

小结:

了解了Hibernate的来源,以及它的工作原理和优缺点。

相信不会再说Hibernate不了解了吧。对于ORM的框架,有多种,如:Nhibernate,Entity,EJB.我们首先要了解整体,细节一定会明确的,可是不能一下子就扎进去了。

Hibernate简单介绍你了解么?

版权声明:本文博主原创文章,博客,未经同意不得转载。

Hibernate一个简短的引论的更多相关文章

  1. Saiku一个简短的引论

    一个简短的引论 Saiku成立于2008年,通过Tom Barber和Paul Stoellberger研究. 最初叫Pentaho分析工具.最初是基于OLAP4J图书馆的使用GWT采用前端分析工具包 ...

  2. HSQL一个简短的引论

    前言     在对dao层写測试类的时候,我们须要一个測试数据库,一般我们会是专门建立一个真实的測试数据库,可是有了HSQLDB事情就变得简单了起来. 正题 一.简单介绍: hsql数据库是一款纯Ja ...

  3. Jsoup一个简短的引论——采用Java抓取网页数据

    转载请注明出处:http://blog.csdn.net/allen315410/article/details/40115479 概述 jsoup 是一款Java 的HTML解析器,可直接解析某个U ...

  4. Mybatis之ResultMap一个简短的引论,关联对象

    基础部分能够查看我的还有一篇博客http://blog.csdn.net/elim168/article/details/40622491 MyBatis中在查询进行select映射的时候.返回类型能 ...

  5. Spark第一个研究笔记1一片 - Spark一个简短的引论

    该公司推出的在线项目Spark拥有近1随着时间的推移.有效,Spark事实上,优秀的分布式计算平台,以提高生产力. 开始本篇笔记.此前的研究会Spark研究报告共享出来(由于篇幅的限制,它将被划分成制 ...

  6. Cache基础知识OR1200在ICache一个简短的引论

    以下摘录<步骤吓得核心--软-core处理器的室内设计与分析>一本书 12.1 Cache基本知识 12.1.1 Cache的作用 处理器的设计者通常会声称其设计的处理器一秒钟能做多少次乘 ...

  7. HTML5分析实战WebSockets一个简短的引论

    HTML5 WebSockets规范定义了API,同意web页面使用WebSockets与远程主机协议的双向通信. 介绍WebSocket接口,并限定了全双工通信信道,通过套接字网络. HTML5 W ...

  8. Oracle 指数 一个简短的引论

    1 索引创建语法: CREATE UNIUQE | BITMAP INDEX <schema>.<index_name>       ON <schema>.< ...

  9. PL/SQL一个简短的引论

    前言 文本 PL/SQL (Procedure Language,程序语言)SQL 1999主要的数据库供应商提供结构化的共同语言  PL/SQL只有支持Oracle数据库 基本的语法 多行凝视   ...

随机推荐

  1. cocos2d-x博客网站推荐和牛逼的教程

    Cocos2d-x网站列表 CocoaChina(官方网站,不解释)www.cocoachina.com/ 泰然网(貌似最近有很多不错的文章,不过早期的文章质量一般)www.ityran.com/ C ...

  2. 22个值得收藏的android开源码-UI篇

    本文介绍了android开发人员中比較热门的开源码,这些代码绝大多数能够直接应用到项目中. FileBrowserView 一个强大的文件选择控件.界面比較美丽,使用也非常easy. 特点:能够自己定 ...

  3. HDOJ 3516 Tree Construction

    四边形优化DP Tree Construction Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 65536/32768 K (Jav ...

  4. php将中文插入数据库出现乱码

    通过php向mysql数据库插入数据,然后在数据库中查看的时候全是乱码(中文),但是取出之后放在页面上仍然正常.就是通过数据库查看的时候全是乱码不能阅读. mysql以UTF-8编码来保存中文,页面提 ...

  5. Java重写方法与初始化的隐患(转)

    原文出处: Shawon 虽然文章标题是Java, 但几乎所有面向对象设计的语言都遵守这个初始化流程, 感谢廖祜秋liaohuqiu_秋百万指出, 之前忘记提这个了. 前言 drakeet写了个和Re ...

  6. eclipse安装ADT后在windows菜单下找不到android SDK and AVD Manager选项的解决办法

    在eclipse中点击window→Customize Perspective→Command Groups availability→Available command groups下勾选Andro ...

  7. uIP中国的协议文件:Ch01

    uIP0.9 参考 by Doxygen 1.3.3 Tue Oct 7 15:51:00 2003 译: fishOnFly(鱼在飞) uIP-refman中文pdf下载 第1章  uIP TCP/ ...

  8. ORACLE 中的 锁 介绍

    ORACLE 中的 锁 介绍 Oracle数据库支持多个用户同时与数据库进行交互,每个用户都可以同时运行自己的事务,从而也需要对并发访问进行控制.Oracle也是用“锁”的机制来防止各个事务之间的相互 ...

  9. MySQL中数据表的增操作

    今天学习到表的增操作,写个博客总结一下,PS:以下所有的凝视都是我在电脑上所有操作完毕后,再拷贝到记事本上加入的.至于在运行的时候可不能够那样加入凝视,就有待考证了. 选择库 mysql> sh ...

  10. [转载]使用python上传图片到 yeelink

    #/bin/env python # -*-coding:utf=8 -*- import os,time,subprocess,shlex import urllib2 def upload_yee ...