背景

  • 持久化技术框架
  • 封装了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. 三分钟玩转微软AI量化投资开源库QLib

    更多精彩内容,欢迎关注公众号:数量技术宅,也可添加技术宅个人微信号:sljsz01,与我交流. 微软QLib简介 微软亚洲研究院发布了 AI 量化投资开源平台"微矿 Qlib".Q ...

  2. 热更新解决方案--tolua学习笔记

    一.tolua使用准备工作:从GitHub上下载tolua(说明:这篇笔记使用的Unity版本是2019.4.18f1c1,使用的tolua是2021年4月9日从GitHub上Clone的tolua工 ...

  3. 201871030116-李小龙 实验二 个人项目—《D{0-1} KP》项目报告

    项目 内容 课程班级博客链接 https://edu.cnblogs.com/campus/xbsf/2018CST 这个作业要求链接 https://www.cnblogs.com/nwnu-dai ...

  4. OO 第二单元

    前言 ​ 第二单元 OO 作业的主题是多线程,课程组通过了电梯调度这个经典问题考察了多线程的调度. ​ 从第五次作业到第七次作业的迭代为,单部多线程可捎带电梯,多部多线程可捎带调度电梯(电梯属性相同) ...

  5. 数栈SQL优化案例:隐式转换

    MySQL是当下最流行的关系型数据库之一,互联网高速发展的今天,MySQL数据库在电商.金融等诸多行业的生产系统中被广泛使用. 在实际的开发运维过程中,想必大家也常常会碰到慢SQL的困扰.一条性能不好 ...

  6. 体渲染——Volume

    基本概念   体渲染(Volume),是绘制类似烟.雾.云的效果.这种渲染和之前的表面渲染不同,光线可以在物体内部进行散射. 体渲染的主要特点    1. 可以在物体内部散射.    2. 从进入vo ...

  7. Polly-故障处理和弹性应对很有一手

    前言 对于运行中的系统,可以说百分百的小伙伴会经常遇见以下问题: 网络不通,突然又好了: 服务器宕机了: 调用服务接口超时了: 调用接口报错啦: 通讯信息发送失败需要重发: 以上只是列举了一些常遇到的 ...

  8. 5. Mybatis UPDATE更新,DELETE删除

    案例: 1. update <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper ...

  9. Oracle-DG最大保护模式下,dg备库出现问题对主库有什么影响?

    一.需求 疑问?Oracle最大保护模式下,dg备库出现问题,影响主库吗? 我们都知道Oracle最大保护模式的意思是oracle不允许数据丢失,1条记录都不行! 那么备库有问题? oracle主库还 ...

  10. poj_1700 题解

    题目描述:在漆黑的夜里,四位旅行者来到了一座狭窄而且没有护栏的桥边. 如果不借助手电筒的话,大家是无论如何也不敢过桥去的. 不幸的是,四个人一共只带了一只手电筒,而桥窄得只够让两个人同时过. 如果各自 ...