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, 用于从数 ...
随机推荐
- mysql的查询、子查询及连接查询
>>>>>>>>>> 一.mysql查询的五种子句 where(条件查询).having(筛选).group by(分组). ...
- linux python更新
linux的yum依赖自带的Python,为了防止错误,此处更新其实是再安装一个Python 1.查看默认python版本 python -v 2.安装gcc,用于编辑Python源码 yum ins ...
- WEB开发入门
对服务器的概念需要更新一下: 从物理上来说,服务器就是一台PC机,至少8核,以T计算,带宽100M以上 一般有的服务器 1. web服务器 -- PC机上安装一个具有web服务的软件 2. 数据库服务 ...
- LeetCode 344. Reverse String
Problem: Write a function that takes a string as input and returns the string reversed. Example: Giv ...
- js/jQuery使用过程中常见问题
目录 一.jQuery选择器选择选中的或者disabled的选择框时attr函数无效 二.jQuery each函数的break/continue 三.jQuery 获取元素的left会值/left数 ...
- jQuery技巧
回到顶部按钮 图片预加载 判断图片是否加载完 自动修补破损图像 Hover切换class类 禁用输入 停止正在加载的链接 toggle fade/slide 简单的手风琴 使两个DIV同等高度 在浏览 ...
- [XAML]类似WPF绑定的Binding的读取方法
在WPF的XAML里,依赖属性可以使用基于BindingBase之类的MarkupExtensin 读取XAML时,会自动的把该BindingBase转换为BindingExpressionBase ...
- Sublime Text3的安装
作为一名前端开发小白,使用Sublime两年多了,从当初的Sublime Text 2到如今的Sublime Text 3,非常喜欢这款轻量级编译器,它不像Dreamweaver那样动辄几百M,只有仅 ...
- java项目启动后,数据库字段生成 user_name带下划线这种形式的
hibernate 5.0 版本以上去掉了 hibernate.naming-strategy = org.hibernate.cfg.ImprovedNamingStrategy 这个属性,如果非 ...
- Sql判断不为Null也不为空的写法
看到不少人写: isnull(field,'')<>'' 其中这样写最经济实惠:field>''