• 接上一章节 HQL的预编译语句

HIbernate中的预编译与Spring的预编译的处理差不多。
 
  1:使用标准的?
 
  2:使用命名参数
 
   2.1:使用名称逐个设置。
 
    2.2:使用Map(key的值等于参数的名称)
 
    2.3:使用Bean(属性的名称等于参数的名称)

案例一:Query_HQL_Prepared.java

package action;

import java.util.HashMap;
import java.util.List;
import java.util.Map; import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.Transaction; import bean.User;
import util.HibernateUtil; /**
* 本类测试HQL的预处理指令
*
* HIbernate中的预编译与Spring的预编译的处理差不多。
*
* 1:使用标准的?
*
*   2:使用命名参数
*
*    2.1:使用名称逐个设置。
*
*    2.2:使用Map(key的值等于参数的名称)
*
*    2.3:使用Bean(属性的名称等于参数的名称)
*
* @author 半颗柠檬、
*
*/
public class Query_HQL_Prepared { public static void main(String[] args) {
// Query_HQL_Prepared.one(); // 使用标准的 ?
// Query_HQL_Prepared.two(); //使用名称逐个设置。
// Query_HQL_Prepared.three(); // 使用Map(key的值等于参数的名称)
Query_HQL_Prepared.four(); //使用Bean(属性的名称等于参数的名称)
} /*
* 使用标准的?
*/
private static void one() {
Session session = null;
Transaction tran = null;
Query query = null;
String hql = "";
try { session = HibernateUtil.getSession();
tran = session.beginTransaction();
hql = " select u from User u where userid<=? and userid>=? and username like ?"; /**
* HQL的索引是从0开始的
*/
query = session.createQuery(hql);
query.setParameter(0, 6);
query.setParameter(1, 1);
query.setParameter(2, "%user%"); List<User> userList = query.list(); for (User user : userList) { System.out.println("username=" + user.getUsername()
+ "\t userid=" + user.getUserid()); } tran.commit();
} catch (Exception e) {
tran.rollback();
e.printStackTrace(); } finally {
HibernateUtil.closeSession();
} } /**
* 使用名称逐个设置
*/
private static void two() {
Session session = null;
Query query = null;
Transaction tran = null;
String sql = "";
try { session = HibernateUtil.getSession();
tran = session.beginTransaction();
sql = " select u from User u where username like :username and userid>= :userid_begin and userid<= :userid_end "; query = session.createQuery(sql);
query.setString("username", "%user%");
query.setInteger("userid_begin", 3);
query.setInteger("userid_end", 5); List<User> userList = query.list(); for (User user : userList) { System.out.println("username=" + user.getUsername()
+ "\t userid=" + user.getUserid()); } tran.commit();
} catch (Exception e) {
e.printStackTrace();
tran.rollback();
} finally {
HibernateUtil.closeSession();
} } /**
* 使用Map(key的值等于参数的名称)
*/
private static void three() { Session session = null;
Transaction tran = null;
Query query = null;
String sql = ""; try {
session=HibernateUtil.getSession();
tran=session.beginTransaction(); sql=" select u from User u where userid>= :userid_begin and userid<= :userid_end and username like :username";
query=session.createQuery(sql); Map<String,Object> sqlMap=new HashMap<String,Object>();
sqlMap.put("userid_begin", 3);
sqlMap.put("userid_end",5);
sqlMap.put("username", "%user%"); query.setProperties(sqlMap); List<User> userList = query.list(); for (User user : userList) { System.out.println("username=" + user.getUsername()
+ "\t userid=" + user.getUserid()); } tran.commit();
} catch (Exception e) {
e.printStackTrace();
tran.rollback();
} finally {
HibernateUtil.closeSession();
} } /**
* 使用Bean(属性的名称等于参数的名称)
*/
private static void four() { Session session = null;
Query query = null;
Transaction tran = null;
String sql=""; try {
session=HibernateUtil.getSession();
tran=session.beginTransaction(); sql=" select u from User u where username like :username and userid>= :userid_begin and userid<= :userid_end "; User user=new User();
user.setUsername("%user%");
user.setUserid_begin(3); //User bean中一定要有userid_begin和userid_end属性,且要有get和set方法
user.setUserid_end(5); query=session.createQuery(sql);
query.setProperties(user); List<User> userList = query.list(); for (User use1r : userList) { System.out.println("username=" + use1r.getUsername()
+ "\t userid=" + use1r.getUserid()); } tran.commit();
} catch (Exception e) {
e.printStackTrace();
tran.rollback();
}finally{
HibernateUtil.closeSession();
}
}
}

(五)Hibernate的增删改查操作(2)的更多相关文章

  1. (四)Hibernate的增删改查操作(1)

    Hiberntae的查找操作有多种: 1.  使用Criteria接口查询 Query_Criteria.java package action; import java.util.ArrayList ...

  2. (六)Hibernate的增删改查操作(3)

    一.在Hibernate中使用原生SQL语句 sql语句面向的是数据库,所以sql语句中对应的不再是bean了,比如sql="select * from user"   在hql中 ...

  3. Hibernate5笔记2--单表的增删改查操作

    单表的增删改查操作: (1)定义获取Session和SessionFactory的工具类: package com.tongji.utils; import org.hibernate.Session ...

  4. (转)SQLite数据库增删改查操作

    原文:http://www.cnblogs.com/linjiqin/archive/2011/05/26/2059182.html SQLite数据库增删改查操作 一.使用嵌入式关系型SQLite数 ...

  5. Android SQLite 数据库 增删改查操作

    Android SQLite 数据库 增删改查操作 转载▼ 一.使用嵌入式关系型SQLite数据库存储数据 在Android平台上,集成了一个嵌入式关系型数据库--SQLite,SQLite3支持NU ...

  6. Scala对MongoDB的增删改查操作

    =========================================== 原文链接: Scala对MongoDB的增删改查操作 转载请注明出处! ==================== ...

  7. python 全栈开发,Day124(MongoDB初识,增删改查操作,数据类型,$关键字以及$修改器,"$"的奇妙用法,Array Object 的特殊操作,选取跳过排序,客户端操作)

    一.MongoDB初识 什么是MongoDB MongoDB 是一个基于分布式文件存储的数据库.由 C++ 语言编写.旨在为 WEB 应用提供可扩展的高性能数据存储解决方案. MongoDB 是一个介 ...

  8. 如何搭建一个WEB服务器项目(二)—— 对数据库表进行基本的增删改查操作

    使用HibernateTemplate进行增删改查操作 观前提示:本系列文章有关服务器以及后端程序这些概念,我写的全是自己的理解,并不一定正确,希望不要误人子弟.欢迎各位大佬来评论区提出问题或者是指出 ...

  9. Go微服务框架go-kratos实战03:使用 gorm 实现增删改查操作

    一.简介 在上一篇文章 go-kratos实战02 中,详细介绍了用 kratos 编写项目代码的步骤.这篇就在上篇基础上,再结合 Go 数据库操作库 gorm 一步一步来实现一个简单的增删改查操作. ...

随机推荐

  1. Flutter移动电商实战 --(46)详细页_自定义TabBar Widget

    主要实现详情和评论的tab provide定义变量 自己做一个tab然后用provide去控制 定义两个变量来判断是左侧选中了还是右侧选中了.并定义一个方法来接受参数,修改是左侧还是右侧选中的状态值 ...

  2. redis不支持多个数据库实例但是支持多个字典

    Redis多个数据库 注意:Redis支持多个数据库,并且每个数据库的数据是隔离的不能共享,并且基于单机才有,如果是集群就没有数据库的概念. Redis是一个字典结构的存储服务器,而实际上一个Redi ...

  3. SQL-W3School-函数:SQL LAST() 函数

    ylbtech-SQL-W3School-函数:SQL LAST() 函数 1.返回顶部 1. LAST() 函数 LAST() 函数返回指定的字段中最后一个记录的值. 提示:可使用 ORDER BY ...

  4. 快速查看MySQL数据库的版本号

    1.利用dos命令连接数据库后即有版本号信息 2.利用navicat连接mysql的客户端工具也是可以查看的 直接选中一个连接,然后右键-连接信息查看 3.利用专门的mysql命令查看 4.直接查看咱 ...

  5. 算法习题---3.01猜数字游戏提示(UVa340)

    一.题目 实现一个经典“猜数字”游戏.给定答案序列和用户猜的序列,统计有多少数字位置正确(A),有多少数字在两个序列都出现过但位置不对(B). 输入包含多组数据.每组输入第一行为序列长度n,第二行是答 ...

  6. NULL和nullptr

    NULL就是0 nullptr是空指针[c++11]

  7. 产品运营数据分析—SPSS数据分组案例

    产品运营数据分析-SPSS数据分组案例 当我们的样本量过大,譬如以前讲过的,EXCEL2010最大只支持1048576行.16384列,尤其是当行数大于30万,一般的办公电脑处理都比较吃力,所以推荐数 ...

  8. (十一)使用Jconsole监控线程

    一.案例 监控线程情况,包括阻塞.死循环等 1.1 代码如下,下述代码共有三个线程,Main.mythread01.mythread02线程,其中mythread01线程为死循环.mythread02 ...

  9. (三)UML之类图关系

    泛化(generalization):表示is-a的关系,是对象之间耦合度最大的一种关系,子类继承父类的所有细节.直接使用语言中的继承表达.在类图中使用带三角箭头的实线表示,箭头从子类指向父类.如下图 ...

  10. activiti的坑

    maven配置: <dependency> <groupId>org.activiti</groupId> <artifactId>activiti-e ...