1.configuration(配置信息管理,产生sessionfactory)

sessionfactory管理一系列的连接池

opensession 永远打开新的,需要手动close

getcurrentsession如果当前环境有,就会用已经存在的,没有就创建新的

一旦提交就没了

getcurrentsession主要用于界定事务边界,事务提交自动close

上下文:在hibernate.cfg.xml里面改   currentsession_context_class

thread:线程  当前线程有没有一个对象,没有就创建i新的,使用connection

jta: 分布式事务 ,Java tarsaction api多数由中间键服务器提供 Tomcat不具备该能力

manager:手动管理事务

custormclass:自己定义

如果使用getcurrentsession必须设定上下文环境

geucurrentsession和sessionopen拿到的类 具体实现可能不一样 因此一般情况下 不建议混用

如果址用hibernate 就要写trycatch

用spring的话就不用写try catch

save();设定一个主键,id

首先搞懂三种状态

三种状态

transient   :内存中的一个对象 缓存中没有对应的id和value

Persistent:内存中有 缓存中有 数据库有 有id

Datached: 内存有 缓存没有 数据库有 有id

save方法即是把transient转化为Persisitence

delete方法

Load

    @Test
public void testLoad() { Session session = sessionFactory.getCurrentSession();
session.beginTransaction();
Teacher t = (Teacher)session.load(Teacher.class, ); session.getTransaction().commit();
System.out.println(t.getClass());
//System.out.println(t.getName());
}

1,自动打包为intege 实现了序列化接口

get

@Test
public void testGet() { Session session = sessionFactory.getCurrentSession();
session.beginTransaction();
Teacher t = (Teacher)session.get(Teacher.class, ); session.getTransaction().commit();
System.out.println(t.getClass());
//System.out.println(t.getName());
}

用load拿出东西的时候才会发出sql语句,不存在对应记录不拿东西不会报错,返回代理对象()

用get拿出对象的时候是直接在数据库加载,不存在对应记录不拿东西也会报错

update

第一种 有detach到persistence 同时数据库更新

    @Test
public void testUpdate1() { Session session = sessionFactory.getCurrentSession();
session.beginTransaction();
Teacher t = (Teacher)session.get(Teacher.class, ); session.getTransaction().commit(); t.setName("zhanglaoshi"); Session session2 = sessionFactory.getCurrentSession();
session2.beginTransaction();
session2.update(t); session2.getTransaction().commit();
}

更新trasent会报错

如果transent设置id数据库并且存在

数据库得有对应的记录

@Test
public void testUpdate2() { Teacher t = new Teacher();
t.setName("zhanglaoshi"); Session session2 = sessionFactory.getCurrentSession();
session2.beginTransaction();
session2.update(t); session2.getTransaction().commit();
}

如果有一个字段特别长 全改就会变低

Load的时候自动会检查缓存是否与数据库一致 如果不一致 就会发update语句 ,所有字段均会更新,如果相同,不会更改

@Test
public void testUpdate4() { Session session = sessionFactory.getCurrentSession();
session.beginTransaction();
Teacher t = (Teacher)session.get(Teacher.class, );
t.setName("zhangsan2");
session.getTransaction().commit();
}

想要只更改一条想要更改的内容

1.加注解(很少用 不够灵活)

anntation

    @Column(updatable = false)
public String getTitle() {
return title;
}
public void setTitle(String title) {
this.title = title;
}

xml:

property属性 update 设置true或者false

2.在xml配置文件上写

<hibernate-mapping>
<class name="com.bjsxt.hibernate.Student" dynamic-update="true">

设置之后在同一个session之后就只更新只更改改的那一部分

跨session的话

@Test
public void testUpdate5() { Session session = sessionFactory.getCurrentSession();
session.beginTransaction();
Student s = (Student)session.get(Student.class, );
s.setName("zhangsan5");
session.getTransaction().commit(); s.setName("z4"); Session session2 = sessionFactory.getCurrentSession();
session2.beginTransaction();
session2.update(s);
session2.getTransaction().commit();
}

他会全部发送,全部更改

如果想要跨session,可以使用merge方法

    @Test
public void testUpdate6() { Session session = sessionFactory.getCurrentSession();
session.beginTransaction();
Student s = (Student)session.get(Student.class, );
s.setName("zhangsan6");
session.getTransaction().commit(); s.setName("z4"); Session session2 = sessionFactory.getCurrentSession();
session2.beginTransaction();
session2.merge(s);
session2.getTransaction().commit();
}

在update之前会先搜索一下 比较是否相同

3.使用hql语句

@Test
public void testUpdate7() { Session session = sessionFactory.getCurrentSession();
session.beginTransaction();
Query q = session.createQuery("update Student s set s.name='z5' where s.id = 1");
q.executeUpdate();
session.getTransaction().commit(); }

Save or update

    @Test
public void testSaveOrUpdate() { Teacher t = new Teacher();
t.setName("t1");
t.setTitle("middle");
t.setBirthDate(new Date()); Session session = sessionFactory.getCurrentSession();
session.beginTransaction();
session.saveOrUpdate(t); session.getTransaction().commit(); t.setName("t2"); Session session2 = sessionFactory.getCurrentSession();
session2.beginTransaction();
session2.saveOrUpdate(t);
session2.getTransaction().commit(); }

没id就save 有id就update

Clear方法

@Test
public void testClear() { Session session = sessionFactory.getCurrentSession();
session.beginTransaction();
Teacher t = (Teacher)session.load(Teacher.class, );
System.out.println(t.getName()); //first session.clear(); Teacher t2 = (Teacher)session.load(Teacher.class, ); //second
System.out.println(t2.getName());
session.getTransaction().commit();

clear用于清除缓存,load和get方法都会先查找缓存,有的话就不会发sql语句

Flush

    @Test
public void testFlush() { Session session = sessionFactory.getCurrentSession();
session.beginTransaction();
Teacher t = (Teacher)session.load(Teacher.class, );
t.setName("tttt"); t.setName("ttttt"); session.getTransaction().commit(); }

如果不加flush的话 他永远只取一次,取最后的

@Test
public void testFlush() { Session session = sessionFactory.getCurrentSession();
session.beginTransaction();
Teacher t = (Teacher)session.load(Teacher.class, );
t.setName("tttt"); session.flush(); t.setName("ttttt"); session.getTransaction().commit(); }

加了flush之后可以强制缓存的内容与数据库的内容做同步

commit方法默认执行flush

在什么时间执行flush由flushmode控制

在前面设置 session.setFlushMode(FlushMode.xxxx)

find方法很老 现在也不怎么用了

SkemaExport

@Test
public void testSchemaExport() {
new SchemaExport(new AnnotationConfiguration().configure()).create(false, true);
}

控制建表语句

Hibernate学习笔记2.5(Hibernate核心开发接口和三种状态)的更多相关文章

  1. Hibernate学习笔记二:Hibernate缓存策略详解

    一:为什么使用Hibernate缓存: Hibernate是一个持久层框架,经常访问物理数据库. 为了降低应用程序访问物理数据库的频次,从而提高应用程序的性能. 缓存内的数据是对物理数据源的复制,应用 ...

  2. Hibernate学习笔记五:反向工程快速开发

    转载请注明原文地址:http://www.cnblogs.com/ygj0930/p/6768513.html  一:反向工程 Myeclipse提供由 数据库表 生成 java pojo 和 hib ...

  3. Hibernate学习笔记--第一个Hibernate框架程序

    一般使用集成开发环境是,把所需的类库添加到项目属性的库路径中,开发工具在部署时会自动复制所需要的类包到WEB-INF\lib目录下 MyEclipse中: 创建项目,右击项目->myeclips ...

  4. C语言学习笔记 (006) - 二维数组传参的三种表现形式

    # include <stdio.h> # include <stdlib.h> # define M # define N int getdate(int (*sp)[M]) ...

  5. Swift 学习笔记 (解决Swift闭包中循环引用的三种方法)

    话不多说 直接上代码 class SmartAirConditioner { var temperature:Int = //类引用了函数 var temperatureChange:((Int)-& ...

  6. Hibernate学习笔记(二)—— 实体规则&对象的状态&一级缓存

    一.持久化类 1.1 什么是持久化类? Hibernate是持久层的ORM映射框架,专注于数据的持久化工作.所谓的持久化,就是将内存中的数据永久存储到关系型数据库中.那么知道了什么是持久化,什么又是持 ...

  7. HIbernate学习笔记(二) hibernate对象的三种状态与核心开发接口

    1.在hibernate中持久化对象有三个状态,这个面试时可能会问到: (1)transient瞬时态:在数据库中没有与之匹配的数据,一般就是只new出了这个对象,并且在session缓存中也没有即此 ...

  8. Spring MVC 学习笔记12 —— SpringMVC+Hibernate开发(1)依赖包搭建

    Spring MVC 学习笔记12 -- SpringMVC+Hibernate开发(1)依赖包搭建 用Hibernate帮助建立SpringMVC与数据库之间的联系,通过配置DAO层,Service ...

  9. Hibernate学习笔记(二)

    2016/4/22 23:19:44 Hibernate学习笔记(二) 1.1 Hibernate的持久化类状态 1.1.1 Hibernate的持久化类状态 持久化:就是一个实体类与数据库表建立了映 ...

随机推荐

  1. golang 入门之struct继承,嵌套

    package main import "fmt" type Jocongmin struct{ Name string Home string Want string } fun ...

  2. flask连接数据库mysql+SQLAlchemy

    使用flask框架链接2种数据库 ----------db.py # -*- coding: utf-8 -*- # Flask hello world from flask import Flask ...

  3. Linux性能及调优指南1.2之Linux内存架构

    本文为IBM RedBook的Linux Performanceand Tuning Guidelines的1.2节的翻译原文地址:http://www.redbooks.ibm.com/redpap ...

  4. .Net 大型分布式基础服务架构横向演变概述(转)

    一. 业务背景 构建具备高可用,高扩展性,高性能,能承载高并发,大流量的分布式电子商务平台,支持用户,订单,采购,物流,配送,财务等多个项目的协作,便于后续运营报表,分析,便于运维及监控. 二. 基础 ...

  5. mysql 存储过程动态拼接sql并执行赋值

    )) BEGIN ## 定义变量 ,) ; ## @表示全局变量 相当于php $ ## 拼接赋值 INTO 必须要用全局变量不然语句会报错 SET @strsql = CONCAT('SELECT ...

  6. jmeter分布式压力测试实践+登录为例

    1.一张分布式压力的图解,如下 准备: 1.两台slave 2.一个master 3.待测目标地址 http://XXX 准备环境:linux环境,master如果可以最好有可视化电脑界面,便于jmx ...

  7. web api 本地测试

    [最简单的,本人小白,大神勿喷] 一:创建web API 服务端 ①创建web api 的项目 ②在这个api项目的Web.config中加上如下几段话: <httpProtocol>&l ...

  8. [Unity动画]06.子状态机

    参考链接: https://www.jianshu.com/p/6b1db3d060ac?utm_campaign=maleskine&utm_content=note&utm_med ...

  9. 分布式计算课程补充笔记 part 1

    ▶ 高性能计算机发展历程 真空管电子计算机,向量机(Vector Machine),并行向量处理机(Parallel Vector Processors,PVP),分布式并行机(Parallel Pr ...

  10. 《算法》第六章部分程序 part 2

    ▶ 书中第六章部分程序,包括在加上自己补充的代码,B-树 ● B-树 package package01; import edu.princeton.cs.algs4.StdOut; public c ...