<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<!-- 映射文件的配置
这就是ORM中的 M!! Mapping 映射文件
Relational Mapping Object
数据库中的表名以及字段 对应 实体类中的类名和属性 package:类所在的包,保证必须是全类名
class:就是配置我们的 实体类相关的信息
name:对应的是实体类的类名或者属性名
table,column:如果与实体类的类名和属性名一致,可以不设置
generator:主键生成策略
01.assigned:必须是我们手动的给ID赋值!ID的生成与数据库无关! 会抛出异常!
02.increment:从数据库表中查询到主键的最大值 (select max(id) from student)!
之后+1把这个值 给我们的主键!ID的生成与数据库有关!
03.identity:针对于mysql数据库中的主键自增
04.sequence:针对于oracle数据库中的序列!
001.在数据库中创建序列
create sequence sq_student_id
minvalue 10
maxvalue 99999999999
start with 10
increment by 10
cache 20;
002.映射文件中配置
<generator class="sequence">
<param name="sequence">sq_student_id</param>
</generator>
003.底层生成的sql语句
select sq_student_id.nextval from dual
首先从数据库中取得当前序列的下一个值! 之后把这个值 给我们的主键! lazy="true" 是默认采用懒加载的方式 获取数据!
不想使用懒加载!lazy="false"
-->
<hibernate-mapping package="cn.bdqn.bean">
<class name="Student" table="student" lazy="false">
<id name="id">
<generator class="assigned"/>
</id>
<property name="age"/>
<property name="name"/>
</class>
</hibernate-mapping>


/**
* jdbc有常用的API
* hibernate也有自己常用的API(核心)
* 01.Configuration 类 :读取我们的核心配置文件----hibernate.cfg.xml
* 接口
* 02.SessionFactory :初始化hibernate需要的各种参数!
* jdbc.properties初始化一次! SessionFactory也是只需要初始化一次即可!写成单例!
*
* 03.Session:之前使用的HttpSession(用户session)! 现在的session叫会话session!
* hibernate就是通过session来操作对象的(增删改查)以及创建事务对象!
* 04.Tranaction :进行事务的处理
* 05.Query :hibernate中的查询接口(SQL,HQL)
* 06.Criteria:hibernate中的查询接口,是对query进行了简单封装!
* 更能体现使用的是面向对象的思想来操作数据库!
*/ public class StudentTest { Session session=null;
Transaction transaction=null;
//在执行测试方法之前 先执行before
@Before
public void before(){
/**
* 01.读取核心的配置文件 在src的根目录下面! 底层规定位置!
* 在实例化Configuration对象的时候通过configure()
* 去src根目录下面,寻找hibernate.cfg.xml文件
*/
Configuration configuration=new Configuration().configure();
//02.创建sessionFactory
SessionFactory sessionFactory = configuration.buildSessionFactory();
//03.打开session
session = sessionFactory.openSession();
//04.开启事务
transaction= session.beginTransaction();
} //在执行测试方法之后
@After
public void after(){
//07.提交事务 sql语句 整体的执行!
transaction.commit();
//08.关闭session
session.close();
//sessionFactory.close(); 验证hbm2ddl中的create-drop
} //新增
@Test
public void addStudent(){
//05.创建一个对象
Student student=new Student(500,5, "小白555");
//06.持久化操作---》将对象保存到数据库中
session.save(student); //不会产生 insert语句
} /**
* 根据id删除指定的学生
*
* 会产生 2条sql语句
* 01.根据id去数据库中查询 有没有对应的数据
* 02.根据id删除 指定delete语句
*/
@Test
public void delStudent(){
Student student=new Student();
student.setId(2); //给对象的ID赋值
//session对象的方法 delete删除
System.out.println("************");
session.delete(student);
System.out.println("************");
}
/**
* 根据id修改指定的学生
* 只会执行一条update语句!
* 如果数据库中没有指定id的数据,没效果!有 就更新!
*/
@Test
public void updateStudent(){
Student student=new Student();
student.setId(1000); //给对象的ID赋值
System.out.println("************");
student.setAge(50);
session.update(student);
System.out.println("************");
} /**
* 查询数据库中指定学生的信息
* 查询 不需要事务!
* get和load的区别
* get:
* 01.在get()立即产生一条sql语句
* 02.首先回去hibernate的1级缓存(session)中查询有没有对应的数据
* 如果有,直接返回,就不会访问数据库!
* 如果没有,去2级缓存中查询(sessionFactory)中查询!
* 如果2级缓存中也没有数据,则会产生一条select语句 访问数据库!
* 03.如果数据库中存在该数据 则返回
* 04.没有对应的数据 返回 null
*/
@Test
public void getStudent(){ //通过get()获取数据
System.out.println("****************");
Student student=(Student) session.get(Student.class, 200);
System.out.println("****************");
System.out.println(student);
} //验证不会访问数据库
@Test
public void getStudent2(){ //通过get()获取数据
Student student=(Student) session.get(Student.class, 200); //被session管理
Student student2=(Student) session.get(Student.class, 200); //缓存中已经存在了
} /**
* evict()从session缓存中 清除指定的对象
*/
@Test
public void evictStudent(){ //通过get()获取数据
Student student=(Student) session.get(Student.class, 200); //被session管理
Student student2=(Student) session.get(Student.class, 300); //被session管理
session.evict(student); //从session缓存中 清除student对象
/**
* 有人认为:1级缓存中确实是清除了!但是2级缓存中应该没有清除吧?
* 不是这么理解的! 2级缓存需要我们手工配置!不配置 就不存在2级缓存!
*/
student=(Student) session.get(Student.class, 200); //再次获取id为200的数据
} /**
* clear() 从session缓存中 清除所有的对象
*/
@Test
public void clearStudent(){ //通过get()获取数据
Student student=(Student) session.get(Student.class, 200); //被session管理
Student student2=(Student) session.get(Student.class, 300); //被session管理
//session.clear(); //从session缓存中 清除所有对象
student=(Student) session.get(Student.class, 200); //再次获取id为200的数据
student2=(Student) session.get(Student.class, 300); //再次获取id为300的数据
} /**
* load: 懒加载
* 01.不会立即产生sql语句
* 02.在用户使用真正对象的时候才去访问数据库!
* 03.首先回去hibernate的1级缓存(session)中查询有没有对应的数据
* 如果有,直接返回,就不会访问数据库!
* 如果没有,去2级缓存中查询(sessionFactory)中查询!
* 如果2级缓存中也没有数据,则会产生一条select语句 访问数据库!
* 04.如果数据库中存在该数据 则返回
* 05.没有对应的数据 返回 ObjectNotFoundException 异常
* 06.如果想实现和 get()一样的效果!怎么做?
* 在对应的hbm.xml文件中的 class节点上 新增 lazy="false" 立即加载!
*/
@Test
public void loadStudent(){ //通过load()获取数据
Student student=(Student) session.load(Student.class, 200);
System.out.println("****************");
System.out.println(student); //产生sql语句
System.out.println("****************");
} }

hibernate03增删改查的更多相关文章

  1. Dapper逆天入门~强类型,动态类型,多映射,多返回值,增删改查+存储过程+事物案例演示

    Dapper的牛逼就不扯蛋了,答应群友做个入门Demo的,现有园友需要,那么公开分享一下: 完整Demo:http://pan.baidu.com/s/1i3TcEzj 注 意 事 项:http:// ...

  2. ASP.NET从零开始学习EF的增删改查

           ASP.NET从零开始学习EF的增删改查           最近辞职了,但是离真正的离职还有一段时间,趁着这段空档期,总想着写些东西,想来想去,也不是很明确到底想写个啥,但是闲着也是够 ...

  3. 构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(9)-MVC与EasyUI结合增删改查

    系列目录 文章于2016-12-17日重写 在第八讲中,我们已经做到了怎么样分页.这一讲主要讲增删改查.第六讲的代码已经给出,里面包含了增删改,大家可以下载下来看下. 这讲主要是,制作漂亮的工具栏,虽 ...

  4. 通过Java代码实现对数据库的数据进行操作:增删改查

    在写代码之前,依然是引用mysql数据库的jar包文件:右键项目-构建路径-设置构建路径-库-添加外部JAR 在数据库中我们已经建立好一个表xs :分别有xuehao  xingming    xue ...

  5. Hibernate全套增删改查+分页

    1.创建一个web工程 2.导入jar包 3.创建Student表 4.创建实体类 package com.entity; public class Student { private Integer ...

  6. 使用 Json.Net 对Json文本进行 增删改查

    JSON 已经成为当前主流交互格式, 如何在C#中使用 Json.Net 对Json文本进行 增删改查呢?见如下代码 #region Create (从零创建) public static strin ...

  7. yii2 增删改查

    自己总结的yii2 advanced 版本的简单的增删改查,希望对大家有所帮助 1.gii生成的actionCreate()方法中 获取插入语句的id $id = $model->attribu ...

  8. Batis-iBatis基本操作(增删改查)

    Batis-iBatis基本操作(增删改查) 时间 2014-04-10 17:55:20  CSDN博客 原文  http://blog.csdn.net/mazhaojuan/article/de ...

  9. JS组件系列——又一款MVVM组件:Vue(一:30分钟搞定前端增删改查)

    前言:关于Vue框架,好几个月之前就听说过,了解一项新技术之后,总是处于观望状态,一直在犹豫要不要系统学习下.正好最近有点空,就去官网了解了下,看上去还不错的一个组件,就抽空研究了下.最近园子里vue ...

随机推荐

  1. Redis的快照持久化-RDB与AOF

    Redis持久化功能 Redis为了内部数据的安全考虑,会把本身的数据以文件形式保存到硬盘中一份,在服务器重启之后会自动把硬盘的数据恢复到内存(redis)的里边. 数据保存到硬盘的过程就称为“持久化 ...

  2. Your project is not referencing the ".NETPortable,Version=v4.5,Profile=Profile259" framework. Add a reference to ".NETPortable,Version=v4.5,Profile=Profile259" in the "frameworks" section of your proj

    i want to add nuget packages to my portable class library project , then i add a project.json to my ...

  3. C#实现无物理边距 可打印区域的绘图\打印 z

    经常在开发实际的应用程序中,需要用到图形绘制和打印程序.如何实现完整的精确打印和绘图是需要注意许多细节地方的.最近在遇到打印问题的时候,仔细研究一阵,总结这篇博文,写得有点杂乱,看文要还请费点神. 基 ...

  4. .Net转Java.01.从Main(main)函数说起

    在C#中,main函数的签名可以有四种 static void Main(string[] args)static void Main()static int Main(string[] args)s ...

  5. fashion datasets图像检索实践project

    Using Siamese Networks and Pre-Trained Convolutional Neural Networks (CNNs) for Fashion Similarity M ...

  6. 【SQL 代码】SQL 语句记录(不定时更新)

    1.数值四舍五入,小数点后保留2位 round() 函数是四舍五入用,第一个参数是我们要被操作的数据,第二个参数是设置我们四舍五入之后小数点后显示几位. numeric 函数的2个参数,第一个表示数据 ...

  7. Visual Studio进行Web性能测试- Part III

    Visual Studio进行Web性能测试- Part III 原文作者:Ambily.raj 对于一个多用户的应用程序,性能是非常重要的.性能不仅是执行的速度,它包括负载和并发方面.Visual ...

  8. linux内核剖析(十)进程间通信之-信号量semaphore

    信号量 什么是信号量 信号量的使用主要是用来保护共享资源,使得资源在一个时刻只有一个进程(线程)所拥有. 信号量的值为正的时候,说明它空闲.所测试的线程可以锁定而使用它.若为0,说明它被占用,测试的线 ...

  9. Effective Java 第三版——76. 争取保持失败原子性

    Tips 书中的源代码地址:https://github.com/jbloch/effective-java-3e-source-code 注意,书中的有些代码里方法是基于Java 9 API中的,所 ...

  10. fastcgi php-cgi与php-fpm区别和之间的关系

    关于FastCGI.php-cgi.php-fpm的区别是什么,各自有什么用途,以及相互间的关系是什么,查阅相关资料,可谓是众说纷纭,莫衷一是: 说法一:fastcgi是一个协议,php-fpm实现了 ...