hibernate学习笔记之四 Hibernate的增删改查
采用JUnit测试,继承TestCase
import java.util.Date; import junit.framework.TestCase; import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration; public class Client extends TestCase{ Configuration config = new Configuration().configure();
SessionFactory factory = config.buildSessionFactory();
Session session = factory.openSession();
一.添加数据
public void testAdd1(){
//user对象进入transient状态
User user = new User();
user.setName("用户1");
user.setCreateTime(new Date());
user.setExpireTime(new Date());
try{
//开启事务
session.beginTransaction();
//session管理user对象,进入Persistent状态
session.save(user);
//提交事务,把内存的改变提交到数据库保存
session.getTransaction().commit();
} catch(Exception e){
e.printStackTrace();
session.getTransaction().rollback();
} finally {
if(session != null && session.isOpen()){
//session.关闭,user对象进入detached状态
session.close();
}
}
}
二.查询数据
使用get查询,没有延迟加载,把需要的一次性都查询出来
使用load查询,有延迟加载,只把需要显示的查询出来,如果还需要查询其他的数据,再次进行查询(在一定程度上提高性能)
查询一条数据
public void testGetOrLoad(){
// User user = (User)session.get(User.class, "2c90e481596c44da01596c44dba30001");
User user = (User)session.load(User.class, "2c90e481596c44da01596c44dba30001");
System.out.println(user.getName());
}
查询表中的所有数据
public void testQuery(){
try{
Query query = session.createQuery("from User");
//建议使用这种方式读取数据,一次都查询出来
List<User> userList = query.list();
for(Iterator<User> iter = (Iterator) userList.iterator(); iter.hasNext(); ){
User user = iter.next();
System.out.println(user.getName());
}
//使用迭代器的方式,每个对象都要查询一次,大量查询时会增加数据库的负担和延迟
// Iterator<User> iter = query.iterate();
// while(iter.hasNext()){
// User user = iter.next();
// System.out.println(user.getName());
// }
} catch(Exception e){
e.printStackTrace();
} finally{
}
}
三.修改数据
public void testUpdate(){
//需要先把数据从数据库中查询出来到对象中,修改对象,再update对象
User user = (User)session.load(User.class, "2c90e481596c44da01596c44dba30001");
user.setName("修改用户");
try{
session.beginTransaction();
session.update(user);
session.getTransaction().commit();
} catch(Exception e){
e.printStackTrace();
session.getTransaction().rollback();
} finally {
if(session != null && session.isOpen()){
session.close();
}
}
}
四:删除数据
public void testDelete(){
//需要先把数据从数据库中查询出来到对象中,再delete对象
User user = (User)session.load(User.class, "2c90e481596c44da01596c44dba30001");
try{
session.beginTransaction();
session.delete(user);
session.getTransaction().commit();
} catch(Exception e){
e.printStackTrace();
session.getTransaction().rollback();
} finally {
if(session != null && session.isOpen()){
session.close();
}
}
}
hibernate学习笔记之四 Hibernate的增删改查的更多相关文章
- Mysql学习笔记(六)增删改查
PS:数据库最基本的操作就是增删改查了... 学习内容: 数据库的增删改查 1.增...其实就是向数据库中插入数据.. 插入语句 insert into table_name values(" ...
- mysql学习笔记一 —— 数据的增删改查
1.连接mysql mysql 直接回车(是以root身份,密码空,登陆的是本机localhost) [root@www mysql]# mysql -uroot -p123 -S /var/lib/ ...
- Mybatis学习笔记之---CRUD(增删改查)
Mybatis的CRUD(增删改查) 1.pom.xml <dependencies> <dependency> <groupId>junit</groupI ...
- Hibernate5笔记2--单表的增删改查操作
单表的增删改查操作: (1)定义获取Session和SessionFactory的工具类: package com.tongji.utils; import org.hibernate.Session ...
- MVC3+EF4.1学习系列(二)-------基础的增删改查和持久对象的生命周期变化
上篇文章中 我们已经创建了EF4.1基于code first的例子 有了数据库 并初始化了一些数据 今天这里写基础的增删改查和持久对象的生命周期变化 学习下原文先把运行好的原图贴来上~~ 一.创建 ...
- MongoDB学习总结(二) —— 基本操作命令(增删改查)
上一篇介绍了MongoDB在Windows平台下的安装,这一篇介绍一下MongoDB的一些基本操作命令. 下面我们直奔主题,用简单的实例依次介绍一下. > 查看所有数据库 (show dbs) ...
- Django基础学习四_数据库的增删改查
今天主要学习两个东西 1.如何对数据库做增删改查 2.如果将数据库中的数据用html的方式返回到前台 一.对数据库中增删改查操作 1.首先需要先见表,见表的方法我们在“http://www.cnblo ...
- mongodb数据库学习【安装及简单增删改查】
//@desn:mongodb数据库学习 //@desn:码字不宜,转载请注明出处 //@author:张慧源 <turing_zhy@163.com> //@date:2018/08/ ...
- Python学习---django之ORM的增删改查180125
模型常用的字段类型参数 <1> CharField #字符串字段, 用于较短的字符串. #CharField 要求必须有一个参数 maxlength, 用于从数 ...
随机推荐
- 当DevOps撞上物联网
DevOps 领域在近年来变得流行而普遍.它强调不同的角色之间共同协作,以及如何工作得更加紧密,就像这个词语的词根暗示的那样--开发和运维.但是DevOps和物联网有什么关系? 本文选自<Dev ...
- 递归 CTE
公用表表达式 (CTE) 具有一个重要的优点,那就是能够引用其自身,从而创建递归 CTE.递归 CTE 是一个重复执行初始 CTE 以返回数据子集直到获取完整结果集的公用表表达式. 当某个查询引用递归 ...
- DelphiXE10.1项目中增加预编译的方法
操作: 菜单选择Proceject->Options->Delphi Compilerz在Conditional Defines(第一行)中添加预编译标识.例:VCL代码:uses{$IF ...
- OSG消息机制之消息分析
OSG消息接收在头文件有各种事件的相关参数
- Struts相关
使用Struts2流程: 1.导入Struts2类包 2.在Web源代码文件夹中,创建名为struts.xml的配置文件.在其中定义Action对象,其关键代码如下: struts.xml: < ...
- Leetcode Implement Queue using Stacks
Implement the following operations of a queue using stacks. push(x) -- Push element x to the back of ...
- 基础2.Jquery过滤选择器
1.基础选择器: 名称 说明 举例 #id 根据元素Id选择 $("divId") 选择ID为divId的元素 element 根据元素的 ...
- ajax 后台正常执行 错误类型却是404
后台执行importExcel,明明方法执行成功,但是前台却提示404 @RequestMapping("/import") public Json importExcel(@Re ...
- 转载:Hadoop排序工具用法小结
本文转载自Silhouette的文章,原文地址:http://www.dreamingfish123.info/?p=1102 Hadoop排序工具用法小结 发表于 2014 年 8 月 25 日 由 ...
- Spark源码编译并在YARN上运行WordCount实例
在学习一门新语言时,想必我们都是"Hello World"程序开始,类似地,分布式计算框架的一个典型实例就是WordCount程序,接触过Hadoop的人肯定都知道用MapRedu ...