[ 学习笔记 ] Hibernate框架学习之一
一、JavaEE开发三层结构和三大框架的对应关系:
Struts2框架 -> 表现层 web层(MVC是表现层的设计模型)
业务层 service层
Hibernate框架 -> 持久层 dao层
Spring框架 ->综合类框架
二、持久层技术有哪些:
JDBC:操作数据库最底层的方式
优势:底层、效率高
弊端:编写代码时比较繁琐,尤其是封装结果集
DBUtils:基于JDBC进行了简单封装
优势:封装结果集操作变得简单,并且仍然是自己编写SQL语句,相对效率没有太大影响
弊端:要求实体类中属性名和数据库表的字段名必须一致
要求记忆东西较多
共同点:都要求自己书写SQL语句
使用JDBC和DBUtils操作产品表的时遇到的问题:
JDBC:查询封装结果时繁琐
DBUtils:保存或更新时繁琐
三、Hibernate概述
Hibernate框架是当今主流的Java持久层框架之一,由于它具有简单易学、灵活性强、扩展性强等特点,能够大大地简化程序的代码量,提高工作效率,因此受到广大开发人员的喜爱。
Hibernate是一个开放源代码的ORM( Object Relational Mapping,对象关系映射)框架,它对JDBC进行了轻量级的对象封装,使得Java开发人员可以使用面向对象的编程思想来操作数据库。它是一个轻量级、企业级、开源的持久层框架(通常情况下,软件工程的持久层解决方案,一个为主一个为辅(写SQL语句(JDBC和DBUtils)和不写SQL语句(Hibernate))),可以操作数据库的框架(框架:一个架构)。
Tips:ORM (Object Relational Mapping):对象关系映射,建立实体类和数据库表的对应关系,实现操作类对象就相当于操作数据库。
操作方式:建立对象关系映射,实现操作实体类就相当于操作数据库表
Tips:轻量级:使用时依赖资源很少(目前使用阶段,只依赖log4j,c3p0连接池)
企业级:指的是在企业级应用中使用的较多
开源的:开放源代码
与其它操作数据库的技术相比, Hibernate具有以下几点优势:
● Hibernate是一个基于JDBC的主流持久化框架,是一个优秀的ORM实现,它很大程度的简化了DAO( Data Access Object,数据访问对象)层编码工作;
● Hibernate的性能非常好,映射的灵活性很出色。它支持很多关系型数据库,从一对一到多对多的各种复杂关系;
● 可扩展性强,由于源代码的开源以及API的开放,当本身功能不够用时,可以自行编码进行扩展。
四、CRM功能模块(Customer Relationship Management)
CRM系统实现了对企业销售、营销、服务等各阶段的客户信息、客户活动进行统一管理。
CRM系统功能涵盖企业销售、营销、用户服务等各各业务流程,业务流程中与客户相关活动都会在CRM系统统一管理,下边列出一些基本的功能模块,包括:客户信息管理、联系人管理、商机管理、统计分析等 ,CRM系统表如下:
2.联系人管理:对客户的联系人信息统一管理,联系人是指客户企业的联系人,即企业的业务人员和客户的哪些人在打交道。
3.客户拜访管理:业务员(用户)要开发客户需要去拜访客户,客户拜访信息记录了业务员与客户沟通交流方面的不足、采取的策略不当、有待改进的地方或值得分享的沟通技巧等方面的信息。
4.综合查询:客户相关信息查询,包括:客户信息查询、联系人信息查询、商机信息查询等。
5.统计分析:按分类统计客户信息,包括:客户信息来源统计、按行业统计客户、客户发展数量统计等。
6.系统管理:系统管理属于crm系统基础功能模块,包括:数据字典、账户管理、角色管理、权限管理、操作日志管理等。
六、搭建Hibernate开发环境
配置SessionFactory过程:
第一部分:
连接数据库的信息:
#hibernate.connection.driver_class com.mysql.jdbc.Driver
#hibernate.connection.url jdbc:mysql:///test
#hibernate.connection.username gavin
#hibernate.connection.password
#hibernate.dialect org.hibernate.dialect.MySQLDialect
第二部分:
hibernate的可选配置:
#hibernate.show_sql true
#hibernate.format_sql true
#hibernate.hbm2ddl.auto update
第三部分:
映射文件的位置
Tips:SQL结构化查询语言:一共分为6个部分
DDL:Data Definition Language 数据定义语言(建库、建表、修改表结构)
DML:Data Manipulation Language 数据库操作语言
DQL:Data Query Language 数据库查询语言
DCL:Data Control Language 数据控制语言(授权)
CCL:Cursor Control Language 游标控制语言(游标操作)
TPL:Transaction Processing Language 事务处理语言(开启、提交、回滚事务)
映射文件的配置:
Hibernate常用配置属性:
七、Hibernate入门案例:
步骤分析: * 1. 解析主配置文件
* 2. 根据配置文件SessionFactory
* 3. 根据SessionFactory创建Session
* 4. 开启事务
* 5. 执行操作(保存)
* 6. 提交事务
* 7. 释放资源
八、hibernate的常用对象:
1.Configuartion:(熟练使用)
常用方法:● 加载核心配置文件:在使用 Hibernate时,首先要创建 Configuration实例,Configuration实例主要用于启动、加载、管理 hibernate的配置文件信息。
● 加载映射文件:Hibernate除了可以使用 Configuration对象加载核心配置文件以外,还可以利用该对象加载映射文件。
2.SessionFactory:(重要)(线程安全,创建单例对象)
● 它是线程安全的,它的同一个实例能够供多个线程共享。
● 它是重量级的,不能随意的创建和销毁。
使用细节:
* 连接数据库信息;
* hibernate基本配置;
* 映射文件的位置以及映射文件中的配置;
* 一些预定义的SQL语句(比如全字段缓存,根据id全字段更新、根据id全字段查询、根据id全字段删除);
* hibernate的二级缓存。
使用原则:一个应用应该只有一个SessionFactory,在应用加载时创建,应用卸载时销毁。
3.Session:(很重要)Session是应用程序与数据库之间交互操作的一个单线程对象,是hibernate运作的中心。
使用原则:一个线程只能有一个Session对象。
常用方法:
● save( ):保存一个实体到数据库;
● update( ):更新一个实体;
● delete( ):删除一个实体;
● get(Class class,Serializable id)和get(Class class,Serializable id):根据id查询一个实体;
● createQuery和createSQLQuery:用于数据库操作对象
● createCriteria():条件查询
● beginTransaction( ):开启事务,并返回事物对象。
4.Transaction:(熟练使用)
常用方法:
● commit( ):提交相关联的session实例;
● rollback( ):撤销事务操作。
九、Hibernate中查询一个实体的方法:(面试考点)
● get方法:get(Class class,Serializable id);
● load方法:load(class class,Serializable id);(load方法默认情况下是延迟,可以通过配置的方式改为立即加载)
共同点:都是根据id查找一个实体
区别:
1.查询的时机不一样:
1.)get方法的查询时机:每次调用get方法时,马上查询 立即加载;
2.) load方法的查询时机:每次真正使用的时候,发起查询 延迟加载(懒加载/惰性加载)。
2.返回结果不一样:
1.) get方法返回的对象是实体类类型;
2.) load方法返回的对象是实体类类型的代理对象。
[ 学习笔记 ] Hibernate框架学习之一的更多相关文章
- Hibernate学习笔记--Hibernate框架错误集合及解决
错误1:MappingException: Unknown entity解决方案 http://jingyan.baidu.com/article/e75aca8552761b142edac6cf.h ...
- 学习笔记:CentOS7学习之十八:Linux系统启动原理及故障排除
目录 学习笔记:CentOS7学习之十八:Linux系统启动原理及故障排除 18.1 centos6系统启动过程及相关配置文件 18.1.1 centos6系统启动过程 18.1.2 centos6启 ...
- HTML+CSS学习笔记 (6) - 开始学习CSS
HTML+CSS学习笔记 (6) - 开始学习CSS 认识CSS样式 CSS全称为"层叠样式表 (Cascading Style Sheets)",它主要是用于定义HTML内容在浏 ...
- 学习笔记:CentOS7学习之二十五:shell中色彩处理和awk使用技巧
目录 学习笔记:CentOS7学习之二十五:shell中色彩处理和awk使用技巧 25.1 Shell中的色彩处理 25.2 awk基本应用 25.2.1 概念 25.2.2实例演示 25.3 awk ...
- 学习笔记:CentOS7学习之二十四:expect-正则表达式-sed-cut的使用
目录 学习笔记:CentOS7学习之二十四:expect-正则表达式-sed-cut的使用 24.1 expect实现无交互登录 24.1.1 安装和使用expect 24.2 正则表达式的使用 24 ...
- 学习笔记:CentOS7学习之二十三: 跳出循环-shift参数左移-函数的使用
目录 学习笔记:CentOS7学习之二十三: 跳出循环-shift参数左移-函数的使用 23.1 跳出循环 23.1.1 break和continue 23.2 Shift参数左移指令 23.3 函数 ...
- 学习笔记:CentOS7学习之二十二: 结构化命令case和for、while循环
目录 学习笔记:CentOS7学习之二十二: 结构化命令case和for.while循环 22.1 流程控制语句:case 22.2 循环语句 22.1.2 for-do-done 22.3 whil ...
- 学习笔记:CentOS7学习之二十一: 条件测试语句和if流程控制语句的使用
目录 学习笔记:CentOS7学习之二十一: 条件测试语句和if流程控制语句的使用 21.1 read命令键盘读取变量的值 21.1.1 read常用见用法及参数 21.2 流程控制语句if 21.2 ...
- 学习笔记:CentOS7学习之二十:shell脚本的基础
目录 学习笔记:CentOS7学习之二十:shell脚本的基础 20.1 shell 基本语法 20.1.1 什么是shell? 20.1.2 编程语言分类 20.1.3 什么是shell脚本 20. ...
随机推荐
- JAVA_SE基础——31.this关键字
黑马程序员入学blog... 也算是学习笔记体会. this的通俗解释: 有一个A类,一个B方法,一个C变量,其中B和C都在类A中 this.B()就是调用A类中的B方法 this.C=1(假设C是一 ...
- php中函数和方法的区别
php的方法就是定义在类里面的方法,一般不建议在方法内部定义方法,但是这种也可以这种叫做内部方法,一般只能本方法调用. 如果定义在同一个类中的方法,在同类的其他方法中调用是$this->方法名就 ...
- Linux的安装和使用技巧
LinuxCentOs开始设置一个普通的用户,如果想进入root用户,可以su然后设置密码,然后第二次再次输入su,然后输入相同的密码就可以进去了 有很多命令需要在root下才能执行,但是在创建时却是 ...
- js中严格模式
我们在js中可以使用"use strict";定义了我们在接下来的文档输写中 将按照严格模式进行: function(){ "use strict'; ;// 在这里我们 ...
- 新概念英语(1-143)A walk through the woods
Lesson 143 A walk through the woods 林中散步 Listen to the tape then answer this question. What was so f ...
- SpringBoot应用的前台目录
一.两个重要目录 templates:存放web页面的模板文件,需要在controller返回视图名称,框架转发才能找到的html. static :存放静态资源,如:html(放在这里可直接访问,如 ...
- Spring Security 入门(1-6-1)Spring Security - 配置文件解析和访问请求处理
1.在pom.xml中添加maven坐标 <dependency> <groupId>org.springframework.security</groupId> ...
- git常用命令行总结
Git是当今最流行的版本控制工具.这几年GitHub也干掉了GoogleCode和Sourceforge,从三大代码仓库中脱颖而出,除了GitHub自身的优秀外,Git也是功不可没. 为何Git如此出 ...
- digest-MD5认证
digest-MD5认证机制是基于MD5算法的LINUX安全机制认证. 会比较用户端传送的杂凑值与使用者密码的杂凑值,以认证用户端. 但由于此机制必须读取使用者密码,因此,所有想透过digest-MD ...
- php过滤表单提交的html等危险代码
表单提交如果安全做得不好就很容易因为这个表单提交导致网站被攻击了,下面我来分享两个常用的php过滤表单提交的危险代码的实例,各位有需要的朋友可参考. PHP过滤提交表单的html代码里可能有被利用引入 ...