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, 用于从数 ...
随机推荐
- 前端优化 - 打开速度1s
先看一下网页的加载流程: 1.解析html结构2.加载外部脚本和样式表文件3.解析并执行脚本(脚本会阻塞页面的加载)4.DOM树构建完成 (DOMContentLoaded)5.加载图片等外部文件6. ...
- haxe jni调用输入法
public static void startInputDialog(final String title, final String text, final String buttonLabel, ...
- c# 如何中List<object>中去掉object对象中的重复列数据?
//去掉重复 var title = modelList.GroupBy(m => m.Title.ToLower().Trim()).Select(m => new { ID = m.F ...
- Unity插件使用总结
移动文件夹位置会引起错误的插件:EasySave2.MaterialUI.Gamestrap UI.Beautify
- [DataMining]WEEK1 - text-retrieval and search engine
What does a computer have to do in order to understand a natural language sentence? What is ambiguit ...
- Django--全文检索功能
经过两个月的时间,毕设终于算是把所有主要功能都完成了,最近这一周为了实现全文检索的功能,也算是查阅了不少资料,今天就在这里记录一下,以免以后再用到时抓瞎了~ 首先介绍一下我使用的Django全文检索逻 ...
- 自定义委托类型 - .Net自带委托类型
委托是一个类,它定义了方法的类型,使得可以将方法当作另一个方法的参数来进行传递. 与其他的类不同,委托类具有一个签名,并且它只能对与其签名匹配的方法进行引用. 一.自定义委托类型 1.语法结构:访问修 ...
- 不可变数组NSArray
//数组里面不允许存放基本数据类型,只能存放“对象” NSArray *array = [NSArray arrayWithObjects:@"周星星",@"尹天仇&qu ...
- POJ 1163 The Triangle(简单动态规划)
http://poj.org/problem?id=1163 The Triangle Time Limit: 1000MS Memory Limit: 10000K Total Submissi ...
- 工作总结_sql
今天客户叫导入数据,因为存在特殊字符,快把我给玩死了,,所以请教...总结 sql 数据导入excel 存在特殊字符引起的数据缺失 利用字符方式 : select a.OpenID+', ...