hibernate的核心思想就是将之前对单个字段的操作变为操作一个对象,使用了ORM(Object relation mapping)对象关系映射的思想

   

·  在hibernate中对数据库特殊字段的有着具体配置,不同的数据库有不同的主键生成策略

      映射到数据的实体对象也需要有以下几点需要注意

  1. 私有化成员变量
  2. 提供get/set方法
  3. 提供无参构造(底层需要反射 反射支持是无参构造)
  4. 类型尽量使用包装类 private int  Integer  因为包装类有null值
  5. 需要有oid( object id )跟主键相对应
  6. 持久化类尽量不使用final修饰

      主键的shengt生成策略、          

        主键的生成有俩个位置可以生成 : JAVA  数据库

        自然主键: 跟业务有关 参与了业务逻辑主要用来区分不同数据 对象 保证数据不重复

        订单表(order_id) 支付 将oid发送了给第三方  第三方响应回来order_id数据

        代理主键: 跟业务无关 主要用来区分不同数据 对象 保证数据不重复

      JAVA

        手动插入

        assigned : 手动插入主键

        自动插入

        increment: 由hibernate 自动查询数据库增长 不适合集群(多个计算机组合成的效果)

        每次查询这个表的最大值 加+1 赋值

      uuid : 自动产生一个随机的id值

    数据库

      native : 根据不同数据的底层自动增长

      identity: mysql的自动增长(auto_increment)  支持自动增长字段 db2 sqlserver

      sequence:oracle 自增长序列

    当然在操作持久化对象的时候,持久化对象也存在三种不同的状态

        对象 在创建到获得 到 session 其实经历了三种状态

      * 瞬时态: 创建一个对象 瞬时态 没有OID 跟session没有关系

      * 持久态: 获得一个对象 (重点) 有OID 跟session有关系

       * 游离态或者脱管态:session关闭后 叫游离态 有OID 跟session没关系

   hibernate的一级缓存和快照机制的原理示意图

      

      

  hibernate对数据库的操作都需要开启事务

    事务指的是  逻辑的一组操作,要么全部成功,要么全部失败

  

事务的特性:

A 原子性: 一组操作 不可再分割

C 一致性: 事务的前后数据保证一致

I 隔离性(lsolation): 多事务之间的操作

D 持久性: 事务不可逆

 

隔离问题:

脏读 : 一个事务读到了另一个事务没有提交的数据

不可重复读: 一个事务读到了另一个事务已提交的数据(update)

虚读/幻读: 一个事务读到了另一个事务已提交的数据(insert)

解决方案:

读未提交 不解决任何问题

读已提交 解决脏读 Oracle默认隔离级别

可重复读 解决脏读 和 不可重复读问题  mysql的默认隔离级别

串行化 解决三个问题

    对事务的配置

   在hibernate的核心配置文件中,

  

    openSession() 表示 每一次调用 获得一个新的session对象

    getCurrentSession() 表示获得当前线程的session对象 等效以前的将connection 绑定的到当前线程上

  hibernate也存在其他的检索方式,但是使用起来要因环境而异

    

  1. oid查询 get/load
  2. 对象导航查询
  3. HQL ( Hibernate Query Language) hibernate查询语言 面向对象
  4. QBC ( Query By Creteria) 比hql更加面向对象  离线查询
  5. SQL

hibernate第二天的更多相关文章

  1. 面试题:hibernate 第二天 快照 session oid 有用

    ## Hibernate第二天 ## ### 回顾与反馈 ### Hibernate第一天 1)一种思想 : ORM OM(数据库表与实体类之间的映射) RM 2)一个项目 : CRM 客户关系管理系 ...

  2. Hibernate第二天——实体类 与缓存机制

    第二天,我们先来了解一下框架里的一个重要概念:实体类 实体类:把数据表或其它持久化数据的格式映射成的类,就是实体类. 实体类的编写规则:由于对应的是javabean,因而也遵循javabean的一些规 ...

  3. Hibernate第二篇【API讲解、执行流程图】

    前言 从上一篇中已经大致介绍了Hibernate并且有了一个快速入门案例的基础了,-.本博文主要讲解Hibernate API 我们看看快速入门案例的代码用到了什么对象吧,然后一个一个讲解 publi ...

  4. SSH框架之Hibernate第二篇

    1.1 持久化类的编写规则 1.1.1 什么是持久化类? 持久化类 : 与表建立了映射关系的实体类,就可以称之为持久化类. 持久化类 = Java类 + 映射文件. 1.1.2 持久化类的编写规则 ( ...

  5. hibernate 第二次深入接触

    1.session 到底如何进行脏处理? 当一个Dept对象加入到session缓存时,Session会为Dept对象的值属性复制一份快照,当Session刷新缓存时,会进行脏处理. 2.OID 用来 ...

  6. ORM和Hibernate的配置方式

    分层体系结构: 逻辑上一般分为三层:表述层(提供与用户交互的界面).业务逻辑层(实现各种业务的逻辑).数据库层(负责存放和管理应用的持久性业务数据). 物理上一般分为两层:物理层(每一层都运行在网络上 ...

  7. hibernate简单应用

    Hibernate 第二章 核心API 和CURD实现 核心API介绍 单表操作方法 查询hql语句 1.认识hibernate 核心思想ORM:实现数据库中的文件一一映射为java中的实体类. 使用 ...

  8. Hibernate框架--对象的状态,缓存, 映射

    回顾Hibernate第二天: 1.  一对多与多对一 2. 多对多 3. inverse/cascade 4. 关联关系的维护 一对多: <set name="映射的集合属性&quo ...

  9. SSH框架之hibernate《二》

    Hibernate第二天     一.hibernate的持久化类和对象标识符         1.1持久化类的编写规范             1.1.1什么是持久化类:               ...

随机推荐

  1. JAVA判断文件的内容类型

    Java 7 新的特性,判断文件的内容类型. Program to demonstrate Java 7 new feature : Determining the file content type ...

  2. java遍历hashMap、hashSet、Hashtable

    一.遍历HashMap Map<Integer, String> map = new HashMap<Integer, String>(); 方法一:效率高 for(Entry ...

  3. 【转】S3C2440与SDRAM NorFlash NandFlash连线分析

    一.SDRAM(HY57V561620F)连线分析 1.  S3C2440 有27根地址线ADDR[26:0],8根片选信号ngcs0-ngcs7,对应bank0-bank7,当访问bankx 的地址 ...

  4. <Mastering KVM Virtualization>:第四章 使用libvirt创建你的第一台虚拟机

    在第3章<搭建独立的KVM虚拟化>中,你安装并启动了libvirtd服务.你还引入了帮助你管理虚拟机的libvirt管理工具virt-manager和virsh. 相较于命令行,新用户总是 ...

  5. parameterType 和 resultType

    parameterType #{} 和 ${} 1.#{}实现的是向prepareStatement中的预处理语句中设置参数值,sql语句中#{}表示一个占位符即?. 2.使用占位符#{}可以有效防止 ...

  6. 网页授权——扫二维码获取openid

    最近做微信公众平台开发项目时遇到这样一个功能需求:生成一个特定url的二维码,用户扫描二维码后跳转到这个url指定的页面,并在这个页面获得用户的openid.这个功能主要涉及到两方面的技术:生成二维码 ...

  7. 微软Tech Summit 2017,等你来打Call

    2017年10月31至11月3日,由微软举办的Tech Summit 2017技术暨生态大会将在北京盛大举办,要在北京连开四天.今年的技术大会看头十足,不仅有大咖级人物带来十二大主题课程,更有三天四场 ...

  8. NFS存储服务部署

    第1章 NFS介绍 1.1 NFS服务内容的概述 □ RPC服务知识概念介绍说明,以及RPC服务存在价值(必须理解掌握) □ NFS服务工作原理讲解(必须理解掌握) □ NFS共享文件系统使用原理讲解 ...

  9. shuffle过程简介--笔记

    数据保存在hdfs上 拿到数据后分片处理 输入到Map 输出键值对 写到缓存,满的时候溢写到磁盘 缓存的数据写入磁盘的过程中,分区排序,合并 多个磁盘文件归并 通知Reduce任务拉取 Map端的sh ...

  10. undefined 与void 0

    参考:https://segmentfault.com/a/1190000000474941 Javascript中void是一个操作符,该操作符指定要计算一个表达式但是不返回值.void 操作符用法 ...