(五)Hibernate的增删改查操作(2)
接上一章节 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)的更多相关文章
- (四)Hibernate的增删改查操作(1)
Hiberntae的查找操作有多种: 1. 使用Criteria接口查询 Query_Criteria.java package action; import java.util.ArrayList ...
- (六)Hibernate的增删改查操作(3)
一.在Hibernate中使用原生SQL语句 sql语句面向的是数据库,所以sql语句中对应的不再是bean了,比如sql="select * from user" 在hql中 ...
- Hibernate5笔记2--单表的增删改查操作
单表的增删改查操作: (1)定义获取Session和SessionFactory的工具类: package com.tongji.utils; import org.hibernate.Session ...
- (转)SQLite数据库增删改查操作
原文:http://www.cnblogs.com/linjiqin/archive/2011/05/26/2059182.html SQLite数据库增删改查操作 一.使用嵌入式关系型SQLite数 ...
- Android SQLite 数据库 增删改查操作
Android SQLite 数据库 增删改查操作 转载▼ 一.使用嵌入式关系型SQLite数据库存储数据 在Android平台上,集成了一个嵌入式关系型数据库--SQLite,SQLite3支持NU ...
- Scala对MongoDB的增删改查操作
=========================================== 原文链接: Scala对MongoDB的增删改查操作 转载请注明出处! ==================== ...
- python 全栈开发,Day124(MongoDB初识,增删改查操作,数据类型,$关键字以及$修改器,"$"的奇妙用法,Array Object 的特殊操作,选取跳过排序,客户端操作)
一.MongoDB初识 什么是MongoDB MongoDB 是一个基于分布式文件存储的数据库.由 C++ 语言编写.旨在为 WEB 应用提供可扩展的高性能数据存储解决方案. MongoDB 是一个介 ...
- 如何搭建一个WEB服务器项目(二)—— 对数据库表进行基本的增删改查操作
使用HibernateTemplate进行增删改查操作 观前提示:本系列文章有关服务器以及后端程序这些概念,我写的全是自己的理解,并不一定正确,希望不要误人子弟.欢迎各位大佬来评论区提出问题或者是指出 ...
- Go微服务框架go-kratos实战03:使用 gorm 实现增删改查操作
一.简介 在上一篇文章 go-kratos实战02 中,详细介绍了用 kratos 编写项目代码的步骤.这篇就在上篇基础上,再结合 Go 数据库操作库 gorm 一步一步来实现一个简单的增删改查操作. ...
随机推荐
- 调用微信公众平台扫一扫示例及解决接口报错 { "errMsg": "config:invalid signature" }
一.解决报错问题 单从报错信息 invalid signature 就可以看出是 签名signature 有问题, 查了很多资料,终于知道了问题点, 后台让我直接调接口是不对的,签名是根据请求接口的页 ...
- Ionic4.x 内置颜色
primary/secondary/tertiary /success/warning/danger/dark/medium/light
- LinearGradient线型渐变效果
public LinearGradient(float x0, float y0, float x1, float y1, int[] colors, float[] positions, TileM ...
- window.open()详解及浏览器兼容性问题示例探讨
这篇文章主要介绍了window.open()的使用及浏览器兼容性问题方面的知识,感兴趣的朋友可以参考下 一.基本语法: window.open(pageURL,name,parameters) 其 ...
- React之概述(待续)
原文链接 MDN上有关JavaScript的内容 箭头函数, 类, 模板字符串, let, const Babel REPL
- 编译安装python3事出错:
configure: error: no acceptable C compiler found in $PATH 问题解决 解决方法: yum intall gcc -y
- DN创建
1. 参考采购订单创建DN : BAPI_OUTB_DELIVERY_CREATE_STO FUNCTION zmmfm0202. *"--------------------------- ...
- LeetCode_28. Implement strStr()
28. Implement strStr() Easy Implement strStr(). Return the index of the first occurrence of needle i ...
- 给 textbox TextMode="password" 赋值后显示出来
在做一个修改用户资料的页面的时候,发现用 <asp:TextBox ID="txtPwd" runat="server" TextMode="P ...
- Git操作记录、腾讯工蜂
腾讯工蜂: http://git.code.tencent.com 登录-->>创建项目-->>获取仓库路径 https://git.code.tencent.com/dang ...