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. C#计算两个时间年份月份差

    C#计算两个时间年份月份差 https://blog.csdn.net/u011127019/article/details/79142612

  2. 各种数据库连接字符串 -- c#

    sqlite : connectionString="Data Source=|DataDirectory|\databasename.db;Pooling=true;FailIfMissi ...

  3. wm_concat函数oracle 11g返回clob

    用wm_concat连接拼接字符串,测试环境是10g,一切正常 到了生产环境是11g,点开直接报错了 wm_concat函数在oracle 10g返回的是字符串,到了11g返回的是clob 解决办法: ...

  4. BIOS备忘录之x86硬件编程(寄存器与IO)

    SOC固件(BIOS)开发: 1.熟悉硬件原理图:要弄清楚pin脚的功能: 2.配置GPIO引脚,配置成Native功能还是GPIO功能(如果是配置成GPIO,需要在code里面显式的使用): 3.硬 ...

  5. 6、Spring-Kafka4

    4.1. Using Spring for Apache Kafka This section offers detailed explanations of the various concerns ...

  6. 5、Spring-Kafka3

    3. Introduction This first part of the reference documentation is a high-level overview of Spring fo ...

  7. bzoj3437 小P的牧场(斜率优化dp)

    3437: 小P的牧场 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 2025  Solved: 1110[Submit][Status][Discu ...

  8. Linux 创建自定义命令

    Linux 创建自定义命令 Linux 可以创建自定义使用命令 这里我们采取使用“alias”命令.这里我们首先了解两个文件,通过这两个文件我们可以根据环境配置相应的自定义命令. 该文件内创建的自定义 ...

  9. 系统安装后的linux和vmware的网络配置

    一.1表示linux的版本   2表示linux内核的版本   3表示操作系统多少位  4.表示操作系统的名称 二.配置虚拟机网络 1.在办公室控制和使用服务器(机房) 2.远程连接 ###配置虚拟机 ...

  10. Spring错误——Spring 注解——factory-bean reference points back to the same bean definition

    背景:学习Spring,在使用注解@Bean的name属性配置<bean>实例时,不能注册实例成功 报错 WARNING: Exception encountered during con ...