背景

  • 持久化技术框架
  • 封装了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. istio in kubernetes (二) -- 部署篇

    在 Kubernetes 部署 Istio [demo演示] 可参考官方文档(https://istio.io/latest/zh/docs/setup/install/) ,以部署1.7.4版本作为 ...

  2. [BFS]最优乘车

    最优乘车 题目描述 HH 城是一个旅游胜地,每年都有成千上万的人前来观光.为方便游客,巴士公司在各个旅游景点及宾馆,饭店等地都设置了巴士站并开通了一些单程巴上线路.每条单程巴士线路从某个巴士站出发,依 ...

  3. 从HotSpot VM源码看字符串常量池(StringTable)和intern()方法

    引言 字符串常量池(StringTable)是JVM中一个重要的结构,它有助于避免重复创建相同内容的String对象.那么StringTable是怎么实现的?"把字符串加入到字符串常量池中& ...

  4. [Fundamental of Power Electronics]-PART I-2.稳态变换器原理分析-2.3 Boost 变换器实例

    2.3 Boost 变换器实例 图2.13(a)所示的Boost变换器器是另一个众所周知的开关模式变换器,其能够产生幅值大于直流输入电压的直流输出电压.图2.13(b)给出了使用MOSFET和二极管的 ...

  5. (二)基于商品属性的相似商品推荐算法——Flink SQL实时计算实现商品的隐式评分

    系列随笔: (总览)基于商品属性的相似商品推荐算法 (一)基于商品属性的相似商品推荐算法--整体框架及处理流程 (二)基于商品属性的相似商品推荐算法--Flink SQL实时计算实现商品的隐式评分 ( ...

  6. day-4 xctf-pwn CGfsb

    xctf-pwn CGfsb 传送门:https://adworld.xctf.org.cn/task/answer?type=pwn&number=2&grade=0&id= ...

  7. 【笔记】《Redis设计与实现》chapter9 数据库

    9.1 服务器中的数据库 Redis服务器将所有都保存在服务器状态redis.h/redisServer结构中 struct redisServer{ //... // 一个数组,保存着服务器中所有数 ...

  8. 在Android、iOS、Web多平台使用AppGallery Connect性能管理服务

    性能管理(App Performance Management,简称APM)是华为应用市场AppGallery Connect(简称AGC)质量系列服务中的其中一项,可以提供分钟级应用性能监控能力,支 ...

  9. matlab数值类型

    matlab数值类型 数值类型的分类 整数类型    整数类型有8种.上面的数字为其内存大小,如:int8,整数所占内存大小为8个字节.除了int64 和 uint64不能进行数值运算之外都可以. 类 ...

  10. Linux(CentOS7)安装与卸载MySQL8.0图文详解

    Mysql数据库的安装对于开发者来说,是我们必然会面对的问题,它的安装过程其实并不复杂,并且网络上的安装教程也非常多,但是对于新手来说,各种不同形式的安装教程,又给新手们带来了要选择哪种方式进行安装的 ...