SSH系列-- hibernate基本原理&&入门demo
Posted 丁国华
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SSH系列-- hibernate基本原理&&入门demo相关的知识,希望对你有一定的参考价值。
什么是hibernate?hibernate在英文中是冬眠的意思,当冬季来临,世界万物开始准备冬眠,但是程序猿这种动物好像不冬眠,因为需求变了,要改bug,冬眠,对于对象来说就是持久化。什么叫做持久化呢?持久化,就是把数据(如内存中的对象)保存到可永久保存的存储设备中,比如磁盘,持久化的主要应用就是将内存中的对象存储在数据库中,或者存储在磁盘文件中、xml文件中等等。持久化是将程序数据在持久状态和瞬时状态间转换的机制。JDBC就是一种持久化机制,文件IO也是一种持久化机制。
在我们的生活当中,也有很多持久化的方法,比如:
a、将鲜肉冷藏,吃的时候再解冻;
b、将水果做成罐头;
c、将人的器官迅速冷冻,运输,然后解冻给需要的人进行移植手术。所以说嘛,学习都是来自于生活。
为了对hibernate进行更加深入的理解,我们可以从以下三个方面来帮助理解hibernate:
a、从UBD的角度
我们知道典型的三层架构有:U层、B层、D层;分别是表示层、业务层、持久层;hibernate就相当于我们之前接触过的D层,也就是持久层框架,持久层框架有很多比如mybatis、EJB等。
b、hibernate是一个开源的ORM框架
ORM,对象关系映射,是一种程序技术,用于实现面向对象编程语言里面不同类型系统的数据之间的转换,从效果上来说,ORM就是创建了一个可在编程语言里使用的虚拟对象数据库,简单来说,她起到的作用就是在关系型数据库和对象之间做一个映射,从对象映射到关系,再从关系映射到对象,这样,我们操作数据库的时候,不需要再和SQL打交道,只要像操作对象一样操作她就可以了
c、hibernate是对jdbc的进一步封装
还记得敲机房个人重构的时候,没有使用hibernate,存在很多的冗余部分,各种JDBC语句,so为了顺应时代的发展,我们把JDBC包装了一下下,这样,我们可以不用操作数据,直接操作她就ok了。
hibernate的优缺点
优点:
a、更加对象化
使用的时候只需要操作对象,是开发更加对象化,抛弃了据库中心的思想,完全的面向对象思想。
b、持久化
带有持久化状态的、具有业务功能的单线程对象,此对象生存期很短。这些对象可能是普通的JavaBeans/POJO,这个对象没有实现第三方框架或者接口,唯一特殊的是他们正与(仅仅一个)Session相关联。一旦这个Session被关闭,这些对象就会脱离持久化状态,这样就可被应用程序的任何层自由使用。(例如,用作跟表示层打交道的数据传输对象。)
c、没有侵入性,即所谓的轻量级框架。
d、移植性很好。
e、缓存机制,提供一级缓存和二级缓存。
f、简洁的HQL编程。
g、提交生产力。
缺点:
a、使用数据库特性的语句,将很难调优
b、对大批量数据更新存在问题
c、系统中存在大量的攻击查询功能
d、不适合批量操作,这也是OR框架的弱点;要使用数据库的特定优化机制的时候,不适合用Hibernate。 e、效率比jdbc略差
hibernate和mybatis
相同点:Hibernate与MyBatis都可以是通过SessionFactoryBuider由XML配置文件生成SessionFactory,然后由SessionFactory 生成Session,最后由Session来开启执行事务和SQL语句。其中SessionFactoryBuider,SessionFactory,Session的生命周期都是差不多的。不同点:
mybatis:小巧、方便、高效、简单、直接、半自动
hibernate:强大、方便、高效、复杂、绕弯子、全自动
a、 入门简单,即学即用,提供了数据库查询的自动对象绑定功能,而且延续了很好的SQL使用经验,对于没有那么高的对象模型要求的项目来说,相当完美。
b、 可以进行更为细致的SQL优化,可以减少查询字段。
c、 缺点就是框架还是比较简陋,功能尚有缺失,虽然简化了数据绑定代码,但是整个底层数据库查询实际还是要自己写的,工作量也比较大,而且不太容易适应快速数据库修改。
d、 二级缓存机制不佳。
hibernate:
a、功能强大,数据库无关性好,O/R映射能力强,如果你对Hibernate相当精通,而且对Hibernate进行了适当的封装,那么你的项目整个持久层代码会相当简单,需要写的代码很少,开发速度很快,非常爽。
b、有更好的二级缓存机制,可以使用第三方缓存。
c、缺点就是学习门槛不低,要精通门槛更高,而且怎么设计O/R映射,在性能和对象模型之间如何权衡取得平衡,以及怎样用好Hibernate方面需要你的经验和能力都很强才行。
举个形象的比喻:
mybatis:机械工具,使用方便,拿来就用,但工作还是要自己来作,不过工具是活的,怎么使由我决定。
hibernate:智能机器人,但研发它(学习、熟练度)的成本很高,工作都可以摆脱他了,但仅限于它能做的事。
hibernate开发以及环境搭建
前面的部分小编主要简单的介绍了hibernate的相关理论知识,接下来,理论联系实践,小编做一个简单的demo,希望可以帮助小伙伴们更好的掌握hibernate,不足之处,还请小伙伴多多指教。
a、Hibernate的环境搭建so easy,各种引入jar包,相关jar文件小编已经上传,点击即可下载,不用积分,不用太感谢啦,小编的名字叫雷锋,Hibernate核心包,Hibernate依赖包。
b、加入数据库驱动,下面的demo的数据库采用mysql,so需要引入mysql的驱动,点击下载。
c、提供核心配置文件hibernate.cfg.xml文件(在src文件夹下即可),其中的配置如下(针对mysql),小伙伴们可以自己查查其他的数据库该如何进行配置。ok下面开始demo:
第一步、编写hibernate.cfg.xml文件,完成基本的配置,代码如下:
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory >
<!-- MySql数据库驱动 -->
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<!-- 数据库名称 -->
<property name="hibernate.connection.url"> jdbc:mysql:///hibernate_first</property>
<!-- 数据库的用户名 -->
<property name="hibernate.connection.username">root</property>
<!-- 数据库的密码 -->
<property name="hibernate.connection.password">123456</property>
<!-- 方言:为每一种数据库提供适配器,方便转换 -->
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
<!-- 显示语句 -->
<property name="hibernate.show_sql">true</property>
<!-- 格式排版 -->
<!-- <property name="hibernate.format_sql">true</property> -->
<mapping resource="com/bjpowernode/hibernate/User.hbm.xml"/>
</session-factory>
</hibernate-configuration>
第二步、建立实体类User.java代码如下所示:
package com.bjpowernode.hibernate;
import java.util.Date;
public class User {
private String id;
private String name;
private String password;
private Date createTime;
private Date expireTime;
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public Date getCreateTime() {
return createTime;
}
public void setCreateTime(Date createTime) {
this.createTime = createTime;
}
public Date getExpireTime() {
return expireTime;
}
public void setExpireTime(Date expireTime) {
this.expireTime = expireTime;
}
}
第三步、编写User.hbm.xml文件,完成实体类的映射,具体代码如下所示:
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<class name="com.bjpowernode.hibernate.User">
<id name="id">
<generator class="uuid"></generator>
</id>
<property name="name"/>
<property name="password"/>
<!-- 下面这种写法获取不到时间,小编也不知道为什么,还请小伙伴多多指教 -->
<!-- <properties name="createTime"/>
<properties name="expireTime"/> -->
<property name="expireTime" column="expireTime" not-null="false" type="date"/>
<property name="createTime" column="createTime" not-null="false" type="date"/>
</class>
</hibernate-mapping>
第四步、将User.hbm.xml文件加入到hibernate.cfg.xml文件中,代码如下所示:
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory >
<!-- MySql数据库驱动 -->
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<!-- 数据库名称 -->
<property name="hibernate.connection.url"> jdbc:mysql:///hibernate_first</property>
<!-- 数据库的用户名 -->
<property name="hibernate.connection.username">root</property>
<!-- 数据库的密码 -->
<property name="hibernate.connection.password">123456</property>
<!-- 方言:为每一种数据库提供适配器,方便转换 -->
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
<!-- 显示语句 -->
<property name="hibernate.show_sql">true</property>
<!-- 格式排版 -->
<!-- <property name="hibernate.format_sql">true</property> -->
<mapping resource="com/bjpowernode/hibernate/User.hbm.xml"/>
</session-factory>
</hibernate-configuration>
第五步、编写工具类ExoprtDB.java,将hbm生成ddl,也就是hbm2ddl,代码如下所示:
package com.bjpowernode.hibernate;
import org.hibernate.cfg.Configuration;
import org.hibernate.tool.hbm2ddl.SchemaExport;
/**
* 将hbm生成ddl
* @author Administrator
*
*/
public class ExportDB {
public static void main(String[] args) {
//默认读取hibernate.cfg.xml文件
Configuration cfg = new Configuration().configure();
SchemaExport export = new SchemaExport(cfg);
export.create(true, true);
}
}
第六步、建立客户端类Client,添加用户数据到myslq,代码如下所示:
package com.bjpowernode.hibernate;
import java.util.Date;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
public class Client {
public static void main(String[] args){
//读取hibernate.cfg.xml文件
Configuration cfg = new Configuration().configure();
//建立SessionFactory
SessionFactory factory = cfg.buildSessionFactory();
//取得session
Session session = null;
try{
session = factory.openSession();
//开启事物
session.beginTransaction();
User user = new User();
user.setName("张三");
user.setPassword("123");
user.setCreateTime(new Date());
user.setExpireTime(new Date());
//保存user对象
session.save(user);
//提交事物
session.getTransaction().commit();
}catch (Exception e){
e.printStackTrace();
//回滚事物
session.getTransaction().rollback();
}finally{
if (session != null){
if(session.isOpen()){
//关闭session
session.close();
}
}
}
}
}
最后,让我们一起来看看效果,如下截图所示:
小编寄语:该博文小编主要简单的介绍了hibernate的相关知识,介绍了什么是hibernate、hibernate的优缺点、hibernate和mybatis的对象,最后简单的介绍了一个入门的demo,通过上面的demo我们可以看出,在代码中没有涉及到任何有关JDBC的代码,作为开发人员只需要写好相应的实体类,然后通过配置就可以实现了表的建立以及向表中实现数据的插入。在代码中有许多Hibernate的核心对象,例如Configuration、SessionFactory、Session等等,随着学习的深入,这些内容小编都会一一相关介绍,SSH之旅,未完待续......
以上是关于SSH系列-- hibernate基本原理&&入门demo的主要内容,如果未能解决你的问题,请参考以下文章