背景

  • 持久化技术框架
  • 封装了JDBC做数据库相关功能开发的重复性工作
  • 比如创建连接,关闭连接,把字段逐一映射到属性中等

使用

  • 在数据库中创建表
  • 创建java project
  • 导入hibernate依赖的jar包
  • 创建实体类,映射数据库中的表
  • 配置Product.hbm.xml
    • 在包com.how2java.pojo下创建
    • 用于映射Product类与数据库中表的对应关系
    • <class name="Product" table="product_">:类Product对应表product_
    • <id name="id" column="id">:属性id,映射表里的字段id
    • <generator class="native"> :id的自增长方式采用数据库的本地方式
  • 配置hibernate.cfg.xml
    • 在src目录下创建 hibernate.cfg.xml
    • 配置访问数据库要用到的驱动,url,账号密码等
    • <property name="dialect">org.hibernate.dialect.MySQLDialect</property>:使用MySQL方言
    • <property name="current_session_context_class">thread</property>:设置事务管理方式为每个线程一个事务
    • <property name="show_sql">true</property>:设置是否在控制台显示执行的sql语句
    • <property name="hbm2ddl.auto">update</property>:是否自动更新数据库的表结构
    • <mapping resource="com/how2java/pojo/Product.hbm.xml" />:识别Product实体类
  • 创建Product对象,通过hibernate把这个对象插入到数据库中
    • 获取SessionFactory
    • 通过SessionFactory 获取一个Session
    • 在Session基础上开启一个事务
    • 调用Session的save方法把对象保存到数据库 
    • 提交事务
    • 关闭Session
    • 关闭SessionFactory

注解

  • 本来放在hbm.xml文件里的映射信息,现在不用配置文件做了,改由注解来完成
  • 配置
    • 把hibernate.cfg.xml 中
    • <mapping resource="com/how2java/pojo/Product.hbm.xml" />
    • 改为
    • <mapping class="com.how2java.pojo.Product" />
  • 与xml比较
    • xml:容易编辑,配置比较集中,方便修改;较繁琐,配置文件过多时难以管理(适合大项目)
    • 注解:方便,简洁;分散到各个class文件中,不易维护(适合小项目)

相关概念

  • HQL

    • hibernate专门用于查询数据的语句,相比于SQL更接近于面向对象的思维方式
  • 事务
    • Hibernate的任何对数据有改动的操作,都应该被放在事务里面(都成功,或都失败)
    • 在Mysql中,只有当表的类型是INNODB的时候,才支持事务
  • 延迟加载(lazyload)
    • 属性的延迟加载:只有访问了这个对象的属性,hibernate才会到数据库中进行查询
    • 关系的延迟加载
  • 级联
    • 没有配置级联的时候,删除分类,其对应的产品不会被删除 
    • 配置了恰当的级联,那么删除分类的时候,其对应的产品都会被删除掉
    • 四种类型
      • all:所有操作都执行级联操作
      • none:所有操作都不执行级联操作
      • delete:删除时执行级联操作
      • save-update:保存和更新时执行级联操作 
  • 缓存
    • 一级缓存存放在session上,hibernate默认开启 
    • 二级缓存在SessionFactory上,在hibernate.cfg.xml中开启(hibernate本身不提供,需安装插件如 EhCache)   
  • 乐观锁
    • 处理脏数据问题
    • <version name="version" column="ver" type="int"></version>
    • 增加一个version字段,用于版本信息控制
    • version元素必须紧跟着id后面,否则会出错

  • 连接池

    • 建立数据库连接比较耗时
    • 通常都会采用数据库连接池的技术来建立多条数据库连接,并且在将来持续使用
    • 节约建立数据库连接的时间,应对高并发量场景
    • hibernate本身提供的数据库连接池不推荐使用,一般会使用第三方的数据库连接池,如C3P0 

[Java] Hibernate的更多相关文章

  1. JAVA Hibernate工作原理及为什么要用

    hibernate 简介:hibernate是一个开源框架,它是对象关联关系映射的框架,它对JDBC做了轻量级的封装,而我们java程序员可以使用面向对象的思想来操纵数据库.hibernate核心接口 ...

  2. JAVA Hibernate工作原理及为什么要用(转)

    hibernate 简介:hibernate是一个开源框架,它是对象关联关系映射的框架,它对JDBC做了轻量级的封装,而我们java程序员可以使用面向对象的思想来操纵数据库.hibernate核心接口 ...

  3. Java Hibernate 之 Session 状态

    Session接口是Hibernate向程序提供操纵数据库的最主要接口,是单线程对象,它提供了基本的保存.更新.删除和查询方法.它有一个缓存,保存了持久化对象,当清理缓存时,按照这些持久化对象同步更新 ...

  4. java Hibernate 处理 oracle xmltype类型

    网上关于如何处理oracle xmltype类型的博客很多,我现在分享的是针对具体业务来的,我在oracle数据库entity表中detail插入了一条xmltype类型的数据 xml的详细内容如下: ...

  5. Java Hibernate中的悲观锁和乐观锁的实现

    锁(locking) 业务逻辑的实现过程中,往往需要保证数据访问的排他性.如在金融系统的日终结算 处理中,我们希望针对某个cut-off时间点的数据进行处理,而不希望在结算进行过程中 (可能是几秒种, ...

  6. java+hibernate+mysql

    实体类News package org.mythsky.hibernatedemo; import javax.persistence.*; @Entity @Table(name="new ...

  7. java Hibernate UUID代码

    package mypack; import java.io.Serializable; import java.net.InetAddress; /** * 唯一主键生成办法.从Hibernate中 ...

  8. Java Hibernate 5.3.x

    SchemeExport Hibernate根据实体类和实体类映射文件自动生成表结构. 示例代码: <?xml version='1.0' encoding='utf-8'?> <! ...

  9. java Hibernate 用法

    Hibernate 用法总结: import java.io.Serializable; import java.sql.SQLException; import java.util.Collecti ...

随机推荐

  1. 前端 | JS 任务和微任务:promise 的回调和 setTimeout 的回调到底谁先执行?

    首先提一个小问题:运行下面这段 JS 代码后控制台的输出是什么? console.log("script start"); setTimeout(function () { con ...

  2. 201871030103-陈荟茹 实验二 个人项目―《D{0-1}KP问题》项目报告

    项目 内容 课程班级博客链接 班级博客链接 这个作业要求链接 作业要求链接 我的课程学习目标 1.理解掌握软件设计的过程中的各个环节2.掌握github的使用,将自己的项目上传至githu中 这个作业 ...

  3. 201871030112-贾傲羊 实验三 结对项目—《D{0-1}KP 实例数据集算法实验平台》项目报告

    项目 内容 课程班级博客链接 课程班级博客链接 这个作业要求链接 作业要求链接 我的课程学习目标 学习PSP流程并运用于结对项目:学习GitHub代码的管理;学习结对编程的流程与内容 这个作业在哪些方 ...

  4. Dynamics CRM报表提示rsProcessingAborted解决方法

    有时候CRM用的好好的突然报表提示了一个错误,rsProcessingAborted如下图: 开始以为是权限问题,在数据库捣鼓了很长时间,服务也重启了很多遍都没效果.后来试了一下重新安装一下报表服务器 ...

  5. 【Prometheus学习笔记】主机监控 -node_exporter

    Exporter for machine metrics prometheus/node_exporter 安装 Prometheus sudo tar -zxvf prometheus-*.tar. ...

  6. MySQL数据库高级三:查询截取分析(了解)

  7. Mybatis3源码笔记(八)小窥MyBatis-plus

    前言 Mybatis-Plus是一个 MyBatis增强工具包,简化 CRUD 操作,在 MyBatis 的基础上只做增强不做改变,为简化开发.提高效率而生,号称无侵入,现在开发中比较常用,包括我自己 ...

  8. API文档大集合

    [API文档大集合] sklearn API:http://sklearn.apachecn.org/cn/0.19.0/tutorial/index.html pandas API:http://p ...

  9. 数据结构之LinkedList | 让我们一块来学习数据结构

    highlight: monokai theme: vue-pro 上一篇文章中使用列表(List)对数据排序,当时底层储存数据的数据结构是数组.本文将讨论另外一种列表:链表.我们会解释为什么有时链表 ...

  10. 如何高效的遍历Map?你常用的不一定是最快的

    微信公众号:大黄奔跑 关注我,可了解更多有趣的面试相关问题. 写在之前 如文章标题所言,遍历Map是开发过程中比较常见的行为,实现的方式也有多种方式,本文带领大家一起看看更加高效的遍历 Map. 『茴 ...