这篇文章用于总结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操作数据库总结的更多相关文章

  1. Java_Web三大框架之Hibernate操作数据库(三)

    使用Hibernate操作数据库需要七个步骤: (1)读取并解析配置文件 Configuration conf = newConfiguration().configure(); (2)读取并解析映射 ...

  2. hibernate操作数据库例子

    1.工程目录结构如下 2.引入需要的jar包,如上图. 3.创建持久化类User对应数据库中的user表 package com.hibernate.配置文件.pojo; import java.sq ...

  3. hibernate操作数据库总结(转)

    一.query方式 1.hibernate使用原生态的sql语句执行数据库查询 有些时候有些开发人员总觉得用hql语句不踏实,程序出现了错误,就猜测因为不是原生态的sql语句,数据库不支持,因此情愿选 ...

  4. Hibernate操作数据库的回调机制--Callback

     1:一般情况下,在使用Hibernate Session存取数据库的代码中,基本上大部分是相同的,如下两个方法所示, //查询Teacher操作 ublic Teacher getTeacher ...

  5. Hibernate 操作数据库

    com.tao.pojo实体类 package com.tao.pojo; public class User { private int id; private String name; priva ...

  6. 转 使用Hibernate操作数据库时报:No CurrentSessionContext configured! 异常

    没有currentSession配置错误,即在我们使用currentSession的时候要在hibernate.cfg.xml中进行相关的事务配置:1.本地事务<property name=&q ...

  7. hibernate操作数据库时报错解决方式

    java.sql.SQLException: Parameter index out of range (28 > number of parameters, which is 27). 这个说 ...

  8. Spring MVC基础知识整理➣Spring+SpringMVC+Hibernate整合操作数据库

    概述 Hibernate是一款优秀的ORM框架,能够连接并操作数据库,包括保存和修改数据.Spring MVC是Java的web框架,能够将Hibernate集成进去,完成数据的CRUD.Hibern ...

  9. 5 -- Hibernate的基本用法 --2 2 Hibernate的数据库操作

    在所有的ORM框架中有一个非常重要的媒介 : PO(持久化对象:Persistent Object).持久化对象的作用是完成持久化操作,简单地说,通过该对象可对数据执行增.删.改的操作 ------ ...

随机推荐

  1. Linux中more命令的实现

    #include <stdio.h> #include <stdlib.h> #include <string.h> #define PAGELEN 24 #def ...

  2. dsplib使用备忘

    1. 到TI官网下载与自己的芯片对应的dsplib库 2. 在工程属性里添加dsplib的头文件路径,lib库路径 3. 在源文件中包含dsplib头文件,如果是在.cpp文件里调用,包含头文件时要用 ...

  3. XML和对象属性互转的基类

    本人做了一个XML和对象属性互转的基类,现在放上来有兴趣拿去看一下,用法很简单,声明一个BaseConversion的子类,该子类与你想转换的对象相对应,然后覆盖基类的两个虚方法,然后在里面写元素与对 ...

  4. [Windows Phone]AnimationHelper管理分散的Storyboard

    问题描述: 在Windows Phone开发时候,可能存在这样的问题: 某一个控件需要一个特定的展现(这里假定是一个特定动画),那么我们会这么解决这个问题呢? 打开Blend,根据需求需求给控件添加动 ...

  5. What is tradebit?

    The Tradebit Fact Sheet What is tradebit?

  6. Linux 技巧之 Grub 超实用技巧

    1. 简单介绍 什么是 GRUB?GRUB 全名Grand Unified Boot Loader,它是一个引导装入器 -- 它负责装入内核并引导 Linux 系统.GRUB 还能够引导其他操作系统, ...

  7. iOS:点击button卡死

    场景:      在tableView的Cell中有一个button,我须要点击这个button然后使得其视图控制器上的一个视图改变frame,可是我点击这个button后,导致卡死,也不崩溃.所有事 ...

  8. Iconfinder 如何杜绝盗版,哈希算法检测图像重复

    原地址:http://blog.jobbole.com/65914/ 本文由 伯乐在线 - 小鱼 翻译自 Silviu Tantos.欢迎加入技术翻译小组.转载请参见文章末尾处的要求. [伯乐在线导读 ...

  9. poj3207(two-sat)

    传送门:Ikki's Story IV - Panda's Trick 题意:给定一个圆,圆上一些点.两点一线.现给出一些线,这些线可以在圆内连起来,也可以在圆外.问有没有可能所有的线画完且不出现相交 ...

  10. 公布AppStore被拒绝的经历

    我们知道IOS发布的版本有很多原因是苹果拒绝发表,我总结了这里3手头上做的原因,他拒绝游,包括同事.朋友拒绝的理由,IOS app参考朋友. 1. 使用非公开API该计划将被拒绝 2. beta版.d ...