1.Hibenate是一个开放源代码的对象关系映射框架,它对JDBC进行了轻量级的对象封装,将pojo类与数据库表建立映射关系,是一个全自动orm框架,Hibenate可以自动生成sql语句,自动执行。

2.核心API:Session、SessionFactory、Transaction、Query、Criteria和Configuration,通过这些接口,可以对持久化对象进行存取、事务控制。

3.Session:Session接口负责执行被持久化对象的CRUD(CRUD任务是完成与数据库的交流,包含了许多常见的sql语句),Session是非线程安全的。这里的是Hibenate的sessoin,不同于jsp的HttpSession,称用户session。

4.SessionFactory:负责初始化Hibenate,充当数据源的代理,并负责创建session对象,SessionFactory并不是轻量级的,一般情况下一个项目有一个SessionFactory,操作多个,需要为每一个数据库创建一个SessionFactory。

5.transaction事务:访问并可能更新数据库各项数据项的一个执行单元。特性:原子性、一致性、隔离性数据库、持久性。

  原子性:一个事务是一个不可分割的工作单位,事务中包括的诸多操作,要么都做要么都不做。

  一致性:事务必须是使数据库从一个一致性状态转变到另一个一致性状态,一致性是与原子性密切相关的。

  隔离性:一个事务的执行不受其他事务的干扰,一个事务内部的操作及使用的数据对并发的其他事务隔离,并发执行的各个事务之间相互不影响。

  持久性:一个事务一旦提交,它对数据库的影响是永久的。接下的操作不当也不会对它产生影响。

6.Query:方便的对数据库及持久化对象进行查询,有两种查询方式HQL语言和本地SQL查询。用来绑定查询,限制查询数量,最终执行查询操作。

7.Criteria:和Query接口类似,允许创建并执行面向对象的标准查询,但它只能和session一起使用。

8.Configuration:作用是配置Hibenate以及启动,Hibenate启动时,首先定位映射文档的位置,读取配置文件,创建一个SessionFactory。

9.有9种主键。。。。:https://baike.so.com/doc/2610851-2756769.html

10.缓存管理:Hibenate有两级Cache(告诉缓存存储器),第一级别的缓存是session缓存,属于事务范围缓存,由Hibenate管理;第二级别的缓存是SessionFactory缓存,属于进程范围或集群范围的缓存,可以进行配置和修改,Hibenate还为查询结果提供了一个查询缓存,依赖于二级缓存。

11.Hibenate工作原理: 

  (1)、通过Configuration().configure();读取并解析hibernate.cfg.xml配置文件

  (2)、由hibernate.cfg.xml中的<mappingresource="com/xx/User.hbm.xml"/>读取解析映射信息。

  (3)、通过config.buildSessionFactory();//得到sessionFactory。

  (4)、sessionFactory.openSession();//得到session。

  (5)、session.beginTransaction();//开启事务。

  (6)、persistent operate;

  (7)、session.getTransaction().commit();//提交事务

  (8)、关闭session;

  (9)、关闭sessionFactory;

学习Hibenate随笔的更多相关文章

  1. html标签学习入门 随笔

    Html学习入门    随笔1: HTML 标题 HTML 标题(Heading)是通过 <h1> - <h6> 等标签进行定义的. 标题仅用于标题文本  不应该被使用在加粗字 ...

  2. linux的学习记录随笔

    为什么学习linux 因为操作系统是一种介质,你要接触其中的东西,首先必须要有介质,而linux在服务器端是老大哥的地位,所以呢,学习linux吧. 学习的方式 可以看视频 imooc.百度传课.网易 ...

  3. 2015.8.1 bootstrap学习(个人每日学习的随笔,比较凌乱

    写在前面: 记录自己的学习中遇到的问题和解决办法.因为是每日晚上总结,可能只是随便一笔带过方便自己记忆.如有写的错误或者凌乱之处,请勿介意 1.<html lang="zh-hans& ...

  4. Java学习的随笔(一)对象概念、this指针、权限修饰符

    最近在看<Java编程思想>,下面按照最近看书的顺序梳理一下心得,由于是初次学习,大部分心得是摘抄自书中: 1. Java中,每个变量都是一个对象. 在创建时首先在内存的堆栈中创建一个该对 ...

  5. 19.10.11学习日记随笔 mysql事务隔离性

    一天的感悟 学习事务的处理方式,其中反想自己学过的flask 默认是开启事务的,flask_sqlalchemy每次在提交时都是需要commit,或者失败是需要rollback回滚操作的,其实pyth ...

  6. 学习varnish随笔

    Varnish是一款高性能.开源的反向代理服务器和缓存服务器.Varnish使用内存缓存文件来减少响应时间和网络带宽消耗.这个项目是由挪威的一家报纸Verdens Gang的网络分支起始的,其架构设计 ...

  7. C# 学习的随笔【随时更新】

    1.结束自己 Application.Exit(); //这个东西有重载函数

  8. 学习java随笔第十一篇:java窗体程序

    要开java的窗体程序,就要下载开发窗体的工具. 这里我用的是的myeclipse,可以直接在网上下载安装即可. 我用的是10.0版本的,如果需要汉化的话,可以看一下这篇文章:myeclipse.10 ...

  9. 学习java随笔第十篇:java线程

    线程生命周期 线程的生命周期:新建状态.准备状态.运行状态.等待/阻塞状态.死亡状态 示意图: 定义.创建及运行线程 线程: package threadrun; //定义一个实现Runnable接口 ...

随机推荐

  1. 51Nod 1058 N的阶乘的长度

    输入N求N的阶乘的10进制表示的长度.例如6! = 720,长度为3.   Input 输入N(1 <= N <= 10^6) Output 输出N的阶乘的长度 Input示例 6 Out ...

  2. SQL语句汇总(二)——数据修改、数据查询

    SQL语句第二篇,不说废话直接开始吧. 首先创建一张表如下,创建表的方法在上篇介绍过了,这里就不再赘述. 添加新数据: INSERT INTO <表名> (<列名列表>) VA ...

  3. Link-Cut-Tree详解

    图片参考YangZhe的论文,FlashHu大佬的博客 Link-Cut-Tree实际靠的是实链剖分,重链剖分和长链剖分珂以参考树链剖分详解 Link-Cut-Tree将某一个儿子的连边划分为实边,而 ...

  4. 剑指offer(25)复杂链表的复制

    题目描述 输入一个复杂链表(每个节点中有节点值,以及两个指针,一个指向下一个节点,另一个特殊指针指向任意一个节点),返回结果为复制后复杂链表的head.(注意,输出结果中请不要返回参数中的节点引用,否 ...

  5. [译]RabbitMQ教程C#版 - "Hello World"

    先决条件 本教程假定 RabbitMQ 已经安装,并运行在localhost标准端口(5672).如果你使用不同的主机.端口或证书,则需要调整连接设置. 从哪里获得帮助 如果您在阅读本教程时遇到困难, ...

  6. Learning-Python【29】:网络编程之粘包

    粘包问题 上一篇博客遗留了一个问题,在接收的最大字节数设置为 1024 时,当接收的结果大于1024,再执行下一条命令时还是会返回上一条命令未执行完成的结果.这就是粘包问题. 因为TCP协议又叫流式协 ...

  7. 虹软SDK在nodejs中的集成

    ==虹软官网地址== http://www.arcsoft.com.cn 在官网注册账号,并且申请人脸识别激活码, 选择SDK版本和运行系统(windows/linux/android/ios) ,我 ...

  8. 《Practical Vim》第五章:命令行模式

    前言 出于历史原因,命令行模式又叫 Ex 模式,它具有的功能有: 读写文件:比如 :edit, :write 等等 创建标签页或者窗口:比如 :tabnew :split 操作缓存区,比如: bnex ...

  9. hdoj5769后缀自动机版本

    网上的题解都是后缀数组,我来个后缀自动机题解. 建好后缀自动机后由于后缀自动机是单向的,那么dfs一遍记录各节点的size,要保证一个节点只经过一次才是O(n),否则是O(n^2).表示这个节点及后面 ...

  10. dedecms 在模版页面获取当前栏目id

    在模版中单独调用当前栏目id {dede:type}[field:ID /]{/dede:type} 在{dede:sql}中调用当前栏目id {dede:sql sql='Select * from ...