Hibernate的初步
1.简介
在java开发领域,基于数据库应用的设计与实现一直都是面向关系的,Hibernate对象/关系映射ORM框架的出现为java面向对象开发提供了易于使用的数据持久化解决方案。
ORM介绍:
(a).ORM(Object Relation Mapping)中文翻译成对象关系映射
(b).ORM是一种为解决“面向对象”与“关系数据库”存在不匹配的现象而出现的一种技术
(c).ORM通过使用描述对象和数据库之间映射的元数据,将java程序中的对象自动持久化到关系数据库中
(d).ORM中的映射关系为:面向对象中的(类/对象/属性)——>面向关系中的(表/表的行(记录)/表的列(字段))
(e).ORM实现的思想:将关系数据库中表的记录(表的行)映射成对象,以对象的形式展现,程序员可以将对数据库的操作转化为对对象的操作
(f).流行的ORM框架:Hibernate , Ibatis , TopLink , apache OJB
Hibernate将java中的对象与对象的关系映射至关系型数据库中成表格与表格的关系,起到了java应用和关系数据库之间的桥梁作用,它封装了JDBC访问数据库的操作,并向上层提供面向对象的数据库访问API。
这里借用网上一张图片来说下Hibernate与JDBC之间的区别:

2.Hibernate运行过程
(a). 应用程序调用configuration类
(b). configuration类读取Hibernate配置文件以及映射文件,并用这些信息生成一个SessionFactory类。
(c).从SessionFactory类生成一个Session对象
(d).用Session对象生成一个Transaction对象
(e).可通过Session对象的get(),load(),save(),update(),delete() 和saveorupdate()等方法对POJO类(plain old java object)进行加载,保存,更新,删除等操作
POJO介绍:
(a') POJO (plain old java object)中文译为:简单的java对象,普通的java类。
(b') POJO 实际意义是普通的JavaBeans(最简单的java类,即一个类只有属性,然后一大堆set,get和tostring方法)
(c') POJO 的特点是支持业务逻辑的协助类,不继承不实现不注释
JavaBean介绍:
(a')JavaBean 是POJODE的Serializable(序列化),它通常是被容器创建(如tomcat),所以它应该具有一个无参数的构造器。同时它也是一种组件技术,不能跨进程访问。
(b') JavaBean 是一种JAVA语言写成的可重用组件。为写成JavaBean,类必须是具体的和公共的,并且具有无参数的构造器。
(c')JavaBean 通过提供符合一致性设计模式的公共方法将内部域暴露成员属性,set和get方法获取。
(d')众所周知,属性名称符合这种模式,其他Java 类可以通过自省机制发现和操作这些JavaBean 的属性。
(f).在查询情况下,可通过Session对象生成一个Query对象,然后利用Query对象执行查询操作;若无异常,Transaction对象将提交这些操作到数据库中,若出现异常,则会回滚。

3.Hibernate项目分层结构:
从比较流行的MVC模式中将Hibernate可以分为如下几个层次
数据层:指数据库的设计
DAO层:DAO(Data Access Object)数据访问对象。DAO层的提出是为了实现把对数据的操作和对业务的操作分离,DAO层直接为上层业务逻辑层提供访问数据的接口。(DAO层比较重要)
业务逻辑层:这里把业务逻辑层封装成一个Service,直接供控制层调用。
控制层和视图层:可见层,采用jsp,Html,css,ajax等。

Hibernate的初步的更多相关文章
- Hibernate知识总结(一)
一.ORM ORM的全称是Object/Relation Mapping,即对象/关系映射,可以将其理解成一种规范,它概述了这类框架的基本特征:完成面向对象的编程语言到关系数据库的映射.可以把ORM看 ...
- Spring入门(四)— 整合Struts和Hibernate
一.Spring整合Struts 1. 初步整合 只要在项目里面体现spring和 strut即可,不做任何的优化. struts 环境搭建 创建action public class UserAct ...
- hibernate初步4
JPA 1.JPA概述 JPA(Java Persistence API)是Sun官方提出的Java持久化规范.它为Java开发人员提供了一种对象/关系映射工具来管理Java应用中的关系数据.,而Hi ...
- Hibernate学习2—Hibernate4 CRUD体验初步
接着上一节,工程结构: jar包没有变化: 一.HibernateUtil 封装: com.cy.util.HibernateUtil.java: package com.cy.util; impor ...
- ssh整合思想初步 structs2 Spring Hibernate三大框架各自要点
Web层用Structs2的action Service层用Spring的IoC和aop以及JdbcTemplate或者Transaction事务(创建对象及维护对象间的关系) Dao层用Hibern ...
- hibernate初步3
事务和并发 1.事务概念 一组不可分割的操作,事务有如下属性(ACID 属性:Atomic Consistent Isolated Durable)(1)原子性---Atomic 事务的原子性指的是 ...
- hibernate初步2
Hibernate级联设计 数据库表之间的关系(主要关系有一对多.一对一.多对多)主要是从如下三个方面体现出来: 1.表体设计 2.实体类的设计 3.配置文件 以下是一些重要级联设计参数属性介绍: c ...
- hibernate初步
Hibernate开发步骤1.新创建工程并且导入相关的包 主要是hibernate.mysql相关的JAR包. 注意:新导入的hibernate相关的JAR包是否与你当前所使用的jdk版本是否兼容,且 ...
- Spring Data初步--整合Hibernate
Spring Data课程中的技术介绍 Hibernate: Hibernate 是一个开放源代码的对象关系映射框架,它对 JDBC 进行了非常轻量级的对象封装,它将 pojo 与数据库表建立映射关系 ...
随机推荐
- Show in Finder OC代码
[[NSWorkspace sharedWorkspace] activateFileViewerSelectingURLs:urls]; /* Activate the Finder, and op ...
- 通过DOS、SHELL批处理命令加载Lib并编译和打包Java项目(或者运行项目)
有些时候,需要通过DOS批处理来编译整个项目的JAVA文件:并且编译后还要对Class文件进行打包成jar文件...这还不是最烦的,最烦的是,编译和打包的时候需要依赖其他多个jar文件,困难就这么来了 ...
- Oracle数据库说明
- 百度地图api根据定位获取附近商家(只获取屏幕内)
根据中心点坐标计算出屏幕2个点(一个最低经纬度,一个最高经纬度),判断这两个点中间的所有坐标的商家..考虑屏幕分辨率之类 移动地图中心点变动,如何异步刷新,判断商家是否已经存在..等... 百度地图a ...
- __get,__set
__get,__set 为php的magic方法,在类中定义为 public 类型. class UserModel { private $id; public $name; public funct ...
- java 实现验证码
package edu.zzuli.common; import java.awt.Color; import java.awt.Font; import java.awt.Graphics2D; i ...
- pptv破解版程序,能够免费观看所有蓝光和会员影片!
pptv破解版程序,能够免费观看所有蓝光和会员影片!PPTV网络电视3.4.1.0012绿色版(去广告本地vip版)由Black Hawk精简破解,去掉播放时缓冲.暂停广告.去掉迷你推荐和推荐弹窗.禁 ...
- Windows Storage Server 2008 R2 Standard(64位)之ASM(Automated Storage Manager)管理
一.服务器管理器之LUN管理 服务器管理器的LUN管理,右键可删除(注意别删了系统分区在的LUN) 二.ASM(Automated Storage Manager) view 高级信息,请不要修改相关 ...
- VS快捷键的简单总结
一.一般的快捷键 Shift+Alt+Enter: 切换全屏编辑 Ctrl+B,T / Ctrl+K,K: 切换书签开关Ctrl+B,N / Ctrl+K,N: 移动到下一书签Ctrl+B,P: 移动 ...
- Uvaoj 11248 Frequency Hopping(Dinic求最小割)
题意:1到n节点(节点之间有一定的容量),需要流过C的流量,问是否可以?如果可以输出possible, 否则如果可以扩大任意一条边的容量 可以达到目的,那么输出possible option:接着输出 ...