hibernate操作数据库总结
这篇文章用于总结hibernate操作数据库的各种方法
一、query方式
1、hibernate使用原生态的sql语句执行数据库查询
有些时候有些开发人员总觉得用hql语句不踏实,程序出现了错误,就猜测因为不是原生态的sql语句,数据库不支持,因此情愿选择回到jdbc时代。这样既耗时耗力,又破坏面向对象的编程。其实,hibernate已经考虑到这个问题,hibernate可以执行原生态的sql语句,正对每种数据库,你可以写对应的sql语句,然后用createSQLQuery(sql)即可。
/**
* 本地sql的检索方式,使用原生态的sql语句检索
*
*/
Session session = this.getSession();
String sql = "select * from course where cid=:id";
Query query = session.createSQLQuery(sql);// 本地SQL检索方式
query.setInteger("id", c_id);
query.list();// 返回持久化的list
2、query执行查询操作(基本方式,字符串连接方式生成hql语句)
query执行查询操作,可以返回唯一对象或者是对象列表
(1)query返回对象列表
/**
* hql的检索方式,执行查询数据库操作,返回对象的列表
* 采用hql语句连接方式
*/
Session session = this.getSession();
String hql = "select * from CourseDO where CId="+id+"";
Query query = session.createQuery(hql);// 本地SQL检索方式
query.list();// 返回持久化的list
(2)query返回唯一对象
/**
* hql的检索方式,执行查询数据库操作,返回唯一对象
* 采用hql语句连接方式
*/
Session session = this.getSession();
String hql = "select * from CourseDO where CId="+id+"";
Query query = session.createQuery(hql);// 本地SQL检索方式
query.uniqueResult();// 返回持久化的list
3、query执行查询操作
hql采用参数方式,其中参数绑定方式分为两种:按照名字绑定,按照位置绑定
(1)hql参数绑定采用按照名字绑定
/**
* hql的检索方式,执行查询数据库操作,返回对象的列表
*
* 参数绑定的形式分为按名字绑定,按位置绑定 此处是按照名字绑定
*/
Session session = this.getSession();
String hql = "select * from CourseDO where CId=:id";
Query query = session.createQuery(hql);// 本地SQL检索方式
query.setInteger("id", c_id);// 名字绑定参数
query.list();// 返回持久化对象的list列表
(2)hql参数绑定采用按照位置绑定
/**
* hql的检索方式,参数绑定的形式分为按名字绑定,按位置绑定 此处是按照位置绑定
*/
String hql = "from CourseDO where CId=?";
Session session = this.getSession();
Query query = session.createQuery(hql);
query.setParameter(0, c_id);// 位置绑定方式
query.uniqueResult();// 检索单个对象,返回唯一值
4、query执行更新,删除操作
利用query的executeUpdate()方法实现
/**
* query执行更新,删除等非查询语句
*
*/
String hql = "delete from CourseDO where CId=? and Time=?";
Session session = this.getSession();
Query query = session.createQuery(hql);
query.setParameter(0, c_id);// 位置绑定方式
query.setDate(1, new Date());// 位置绑定方式,设置为Date类型
query.executeUpdate();// 执行delete,update和insert into 语句
二、hibernate模版方法
利用hibernate模版方法执行hql语句非常简单,但是有时候不是那么方便,可以自己选择使用。
1、hibernateTemplate查询数据库
/**
* 利用hibernate模版方法进行查询,绑定参数形式
*
*/
String hql = "from CourseDO where CId=? and Date=?";
List<CourseDO> courseDOs = getHibernateTemplate().find(hql, c_id,
new Date());
2、hibernateTemplate更新数据
/**
* 利用hibernate模版方法进行更新,绑定参数形式
*
*/
List<CourseDO> courseDOs = getHibernateTemplate().update(courseDO);
3、hibernateTemplate插入数据
/**
* 利用hibernate模版方法进行插入,绑定参数形式
*
*/
List<CourseDO> courseDOs = getHibernateTemplate().save(courseDO);
4、hibernateTemplate删除数据
/**
* 利用hibernate模版方法进行删除,绑定参数形式
*
*/
List<CourseDO> courseDOs = getHibernateTemplate().delete(courseDO);
hibernate操作数据库总结的更多相关文章
- Java_Web三大框架之Hibernate操作数据库(三)
使用Hibernate操作数据库需要七个步骤: (1)读取并解析配置文件 Configuration conf = newConfiguration().configure(); (2)读取并解析映射 ...
- hibernate操作数据库例子
1.工程目录结构如下 2.引入需要的jar包,如上图. 3.创建持久化类User对应数据库中的user表 package com.hibernate.配置文件.pojo; import java.sq ...
- hibernate操作数据库总结(转)
一.query方式 1.hibernate使用原生态的sql语句执行数据库查询 有些时候有些开发人员总觉得用hql语句不踏实,程序出现了错误,就猜测因为不是原生态的sql语句,数据库不支持,因此情愿选 ...
- Hibernate操作数据库的回调机制--Callback
1:一般情况下,在使用Hibernate Session存取数据库的代码中,基本上大部分是相同的,如下两个方法所示, //查询Teacher操作 ublic Teacher getTeacher ...
- Hibernate 操作数据库
com.tao.pojo实体类 package com.tao.pojo; public class User { private int id; private String name; priva ...
- 转 使用Hibernate操作数据库时报:No CurrentSessionContext configured! 异常
没有currentSession配置错误,即在我们使用currentSession的时候要在hibernate.cfg.xml中进行相关的事务配置:1.本地事务<property name=&q ...
- hibernate操作数据库时报错解决方式
java.sql.SQLException: Parameter index out of range (28 > number of parameters, which is 27). 这个说 ...
- Spring MVC基础知识整理➣Spring+SpringMVC+Hibernate整合操作数据库
概述 Hibernate是一款优秀的ORM框架,能够连接并操作数据库,包括保存和修改数据.Spring MVC是Java的web框架,能够将Hibernate集成进去,完成数据的CRUD.Hibern ...
- 5 -- Hibernate的基本用法 --2 2 Hibernate的数据库操作
在所有的ORM框架中有一个非常重要的媒介 : PO(持久化对象:Persistent Object).持久化对象的作用是完成持久化操作,简单地说,通过该对象可对数据执行增.删.改的操作 ------ ...
随机推荐
- 一劳永逸解决UAC问题(修改QMAKE_LFLAGS_EXE的设置)
如果你的程序跑在一个开启了UAC保护的系统中,而你的程序又没有"盾牌"的话,程序总是会受到各种阻挠的,比如读写文件,写注册表等. 有了"盾牌"的话就不会出现一些 ...
- Linux Shell常用技巧(二) grep
七. grep家族: 1. grep退出状态: 0: 表示成功: 1: 表示在所提供的文件无法找到匹配的pattern: 2: 表示参数中提供的文件不存在. 见如 ...
- 让Android中的webview支持页面中的文件上传
android webview在默认情况下是不支持网页中的文件上传功能的: 如果在网页中有<input type="file" />,在android webview中 ...
- ANSI C中取得结构体字段偏移量的常用方法
来自http://blog.chinaunix.net/u2/62910/showart_492571.html 假设在ANSI C程序中定义了一个名为MyStruct的结构类型,其中有一个名为MyF ...
- C++著名类库和C++标准库介绍
C++著名类库 1.C++各大有名库的介绍——C++标准库 2.C++各大有名库的介绍——准标准库Boost 3.C++各大有名库的介绍——GUI 4.C++各大有名库的介绍——网络通信 5.C++各 ...
- hdu 2594 Simpsons’ Hidden Talents 【KMP】
题目链接:http://acm.acmcoder.com/showproblem.php?pid=2594 题意:求最长的串 同一时候是s1的前缀又是s2的后缀.输出子串和长度. 思路:kmp 代码: ...
- 一个发送邮件的C++库–jwsmtp
接收邮件的,暂时没搞定,不过在SF上找到了这个发送邮件的库文件.它提供了一个比较完整的类,可以简单的调用发送邮件.下面是作者提供的一个例子,不过由于连SMTP发邮件需要密码,所以代码我改了一下.// ...
- Android 异步链式调用设计
本文讨论一下异步链式调用的设计与实现. 考虑如下情况: 情况1: 访问网络(或其他耗时的事情).通常的做法是: 1.显示一个ProgressDialog对话框,提示用户. 2.启动工作线程来执行耗时操 ...
- ubuntu12.04下搭建ftpserver
楼主想把同学硬盘里面的200多G电影共享给实验室的小伙伴们看,就打算在内网server上搭建一个ftp的server. 1.安装ftp 首先在终端下键入例如以下内容,安装ftpserver: sudo ...
- VSTO学习笔记(四)从SharePoint 2010中下载文件
原文:VSTO学习笔记(四)从SharePoint 2010中下载文件 上一次我们开发了一个简单的64位COM加载项,虽然功能很简单,但是包括了开发一个64位COM加载项的大部分过程.本次我们来给CO ...