(五)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 一步一步来实现一个简单的增删改查操作. ...
随机推荐
- legend3---lamp.sh常用操作
legend3---lamp.sh常用操作 一.总结 一句话总结: 1.github上下载代码 2.修改项目数据库配置,修改文件权限等操作:chown -R apache:apache /data/w ...
- Canvas恢复布局
package com.loaderman.customviewdemo; import android.content.Context; import android.graphics.Canvas ...
- Django开发简单采集用户浏览器信息的小功能
Django开发简单采集用户浏览器信息的小功能 Centos环境准备 yum install –y python-pip export http_proxy=http://10.11.0.148:80 ...
- No WebApplicationContext found: no ContextLoaderListener registered
修改前运行报错:No WebApplicationContext found: no ContextLoaderListener registered? <web-app> <dis ...
- VL10B 采购订单转DN
传入采购订单项目建交货单 FUNCTION zmmfmXXXX. *"------------------------------------------------------------ ...
- activity 工作流
https://blog.csdn.net/cs_hnu_scw/article/details/79059965 https://blog.csdn.net/xnf1991/article/deta ...
- MySQL必知必会:组合查询(Union)
MySQL必知必会:组合查询(Union) php mysqlsql 阅读约 8 分钟 本篇文章主要介绍使用Union操作符将多个SELECT查询组合成一个结果集.本文参考<Mysql ...
- WPF引入OCX控件
(方法一) https://www.cnblogs.com/guaniu/archive/2013/04/07/3006445.html (方法二) 1.先注册OCX控件:(有的把OCX 控件封装到E ...
- 【Leetcode_easy】594. Longest Harmonious Subsequence
problem 594. Longest Harmonious Subsequence 最长和谐子序列 题意: 可以对数组进行排序,那么实际上只要找出来相差为1的两个数的总共出现个数就是一个和谐子序列 ...
- Unity接入九游SDK学习与踩坑
学习之路漫漫,应修之期远兮.持之以恒,方得始终. 这几日接入九游SDK,于浑浑噩噩中成长. 下面是步骤: 一:下载九游SDK 二:打开Android Studio新建一个工程,并且新建一个Androi ...