HibernateCRUD基础框架(2)-HQL语句构造器(HqlQueryBuilder,HqlUpdateBuilder)
上篇讲述了最基本的实体类,本篇接着讲述HQL语句构造器,包括查询和更新等。
优点:通过面向对象的方式构造HQL语句,更快捷,不需要手动拼接HQL。
缺点:封装可能降低性能,只能支持常用的和较为简单的HQL构造。
部分功能不完善,待开发。
1.HQL语句构造器
package cn.fansunion.hibernate.sql; import org.apache.commons.lang.text.StrBuilder; import cn.fansunion.hibernate.sql.entity.From;
import cn.fansunion.hibernate.sql.entity.GroupBy;
import cn.fansunion.hibernate.sql.entity.OrderGroup;
import cn.fansunion.hibernate.sql.entity.SearchCondition; /**
* HQL语句构造器。
* <p/>
* 目前只适用于1张表的情况,只有查询条件支持占位符,建议使用完全构造的sql语句(是否会产生sql注入,待研究)。
*
* @author LeiWen@FansUnion.cn
*/
public class HqlQueryBuilder extends ConstantBase { // 查询条件组合策略
// -----------------------------------
// *************From******************
// -----------------------------------
private String select; private From from; // -----------------------------------
// *************Where******************
// -----------------------------------
private SearchCondition searchCondition; // -----------------------------------
// *************Group by**************
// ----------------------------------- private GroupBy groupBy; // -----------------------------------
// *************Order by******************
// -----------------------------------
private OrderGroup orderGroup; // -----------------------------------
// 通过构造方法,创建查询构造器。各种字段组合形式的构造方法太多,只给出3种比较常见的。
// 建议使用链式构造或setter方法设置属性。
// -----------------------------------
public HqlQueryBuilder() { } public HqlQueryBuilder(From from) {
this.from = from;
} public HqlQueryBuilder(From from, SearchCondition searchCondition,
GroupBy groupBy, OrderGroup orderGroup) {
this.from = from; this.searchCondition = searchCondition;
this.groupBy = groupBy;
this.orderGroup = orderGroup;
} public HqlQueryBuilder select(String select) {
this.select = select;
return this;
} // -----------------------------------
// 支持链式用法,暂时不能很好地支持**************
// -----------------------------------
public HqlQueryBuilder from(From from) {
this.from = from;
return this;
} public HqlQueryBuilder from(String model) {
doFrom(model, "");
return this;
} public HqlQueryBuilder from(String model, String alias) {
doFrom(model, alias);
return this;
} public HqlQueryBuilder from(Class<?> clazz) {
doFrom(clazz.getSimpleName());
return this;
} public HqlQueryBuilder from(Class<?> clazz, String alias) {
doFrom(clazz.getSimpleName(), alias);
return this;
} private void doFrom(String model) {
doFrom(model, null);
} private void doFrom(String model, String alias) {
this.from = new From(model, alias);
} public HqlQueryBuilder searchCodition(SearchCondition searchCondition) {
this.searchCondition = searchCondition;
return this;
} public HqlQueryBuilder groupBy(GroupBy groupBy) {
this.groupBy = groupBy;
return this;
} public HqlQueryBuilder orderBy(OrderGroup orderGroup) {
this.orderGroup = orderGroup;
return this;
} /**
* 转换成HQL语句
*/
public String toHql() { StrBuilder builder = new StrBuilder();
if (select != null) {
builder.append(select).append(EMPTY);
}
if (from != null) {
builder.append(from);
} if (searchCondition != null) {
builder.append(searchCondition);
}
if (groupBy != null) {
builder.append(groupBy);
}
if (orderGroup != null) {
builder.append(orderGroup);
} return builder.toString();
} }
2.Hql更新语句构造器
下面这个是构造更新HQL语句的构造器,待完善。
package cn.fansunion.hibernate.sql.update; import java.util.HashMap;
import java.util.Map; import cn.fansunion.hibernate.util.Pair; /**
* Hql更新语句构造器。(TODO 待完善)
*
* @author LeiWen@FansUnion.cn
*/
public class HqlUpdateBuilder { private Map<String, Object> params; private String model; public HqlUpdateBuilder() {
params = new HashMap<String, Object>();
} public HqlUpdateBuilder(String model) { } public HqlUpdateBuilder(Class<?> model) {
this.model = model.getSimpleName();
} public HqlUpdateBuilder model(String model) {
this.model = model;
return this;
} public HqlUpdateBuilder model(Class<?> model) {
this.model = model.getSimpleName();
return this;
} public HqlUpdateBuilder param(String key, Object value) {
params.put(key, value);
return this;
} public HqlUpdateBuilder param(Pair... pair) {
for (Pair p : pair) {
params.put(p.getKey(), p.getValue());
}
return this;
} public HqlUpdateBuilder param(Map<String, Object> params) {
this.params.putAll(params);
return this;
} public String toHql() {
String hql = "update " + model + " set ";
for (Map.Entry<String, Object> entry : params.entrySet()) {
String key = entry.getKey();
hql += key + "=:" + key + " ";
}
return hql;
} }
3.原生SQL语句构造器
类似的,有时候,可能不用Hibernate的HQL,而是用原生的SQL。
这个时候,可以编写与HqlQueryBuilder和HqlUpdateBuilder相应的SQL版本。
package cn.fansunion.hibernate.sql; import cn.fansunion.hibernate.sql.entity.Limit; /**
* 原生SQL语句构造器。(TODO 待完善)
*
* @author LeiWen@FansUnion.cn
*/
public class SqlQueryBuilder {
// limit只适用于nativeSQL
// -----------------------------------
// *************limit**************
// -----------------------------------
private Limit limit; /**
* 转换成SQL语句
*/ public String toSql(){
//TODO
return null;
}
}
4.HQL查询构造器使用例子
/**
* HQL查询构造器使用例子。
*
* @author LeiWen@FansUnion.cn
*/
public class HqlQueryBuilderTest extends ConstantBase { @Test
public void test() {
From from = new From(HqlQueryBuilder.class);
SearchCondition searchCondition = createSearchCondtion();
OrderGroup orderGroup = createOrderGroup();
GroupBy groupBy = createGroupBy();
HqlQueryBuilder builder = new HqlQueryBuilder(from, searchCondition,
groupBy, orderGroup);
// 直接打印,不使用“断言”
println(builder.toHql());
} private GroupBy createGroupBy() {
GroupBy groupBy = new GroupBy();
groupBy.addGroup("name");
groupBy.addGroup("id");
return groupBy;
} private OrderGroup createOrderGroup() {
Order order1 = new Order("id", false);
Order order2 = new Order("name", "asc"); OrderGroup orderGroup = new OrderGroup(order1, order2);
return orderGroup;
} private SearchCondition createSearchCondtion() {
GroupCondition groupCondition1 = oneGroupCondition();
GroupCondition groupCondition2 = oneGroupCondition();
//String groupStr1 = groupCondition1.toString();
//String groupStr2 = groupCondition2.toString();
// System.out.println(groupStr1);
// System.out.println(groupStr2); SearchCondition searchCondition = new SearchCondition();
searchCondition.addGroupCondition(groupCondition1);
searchCondition.addGroupCondition(groupCondition2, true);
//String searchStr = searchCondition.toString();
// System.out.println(searchStr);
return searchCondition;
} private GroupCondition oneGroupCondition() {
// =,Integer
String age = "age";
Integer ageValue = 24;
Condition condition2 = new Condition(age, Operator.EQUALS, ageValue);
String str2 = condition2.toString(); Assert.assertEquals(str2, age + EQUALS_WITH_BLANK + ageValue); // =,String
String name = "name";
String nameValue = "LeiWen@FansUnion.cn";
Condition condition = new Condition(name, Operator.EQUALS, nameValue);
String str = condition.toString();
Assert.assertEquals(str, name + EQUALS_WITH_BLANK
+ buildQuota(nameValue)); // =,Date
String date = "date";
Date dateValue = new Date();
Condition condition3 = new Condition(date, Operator.EQUALS, dateValue);
String str3 = condition3.toString();
Assert.assertEquals(str3, date + EQUALS_WITH_BLANK
+ buildQuota(dateValue)); GroupCondition groupCondition1 = new GroupCondition();
groupCondition1.addCondition(condition);
groupCondition1.addCondition(condition2, true);
groupCondition1.addCondition(condition3, false);
return groupCondition1;
} }
5.输出结果
from HqlQueryBuilder where (name = 'LeiWen@FansUnion.cn' or age = 24 and date = 'Mon Dec 30 16:57:21 CST 2013')
or (name = 'LeiWen@FansUnion.cn' or age = 24 and date = 'Mon Dec 30 16:57:21 CST 2013')
group by name,id order by id desc,name asc
原文链接:http://blog.fansunion.cn/articles/3622(小雷博客-blog.fansunion.cn)
HibernateCRUD基础框架(2)-HQL语句构造器(HqlQueryBuilder,HqlUpdateBuilder)的更多相关文章
- HibernateCRUD基础框架(1)-实体类
		
HibernateCRUD基础框架包括3篇文章,主要讲述整个CRUD基础框架的思路. 第1篇:讲述最基本的实体类,这些实体类是对SQL语言中的一些概念的封装. 第2篇:在这些实体类的基础上,开发一个& ...
 - HibernateCRUD基础框架(3)-简单的和较为复杂的标准的CRUD API
		
优点:简单的和基础的CRUD功能可以很快实现,可以说是比较的"标准化".维护起来也很容易. 缺点:性能没有保障.不支持特别复杂的CRUD. 可以适用的场景:小型Web项目 1.Cr ...
 - Hibernate框架HQL语句
		
这篇随笔将会记录hql的常用的查询语句,为日后查看提供便利. 在这里通过定义了三个类,Special.Classroom.Student来做测试,Special与Classroom是一对多,Class ...
 - 用Hibernate框架把hql生成可执行的sql语句-Oracle方言
		
引言:为什么这样的需求,源自公司项目需要,公司的项目使用java的struts2+spring2.5+oracle中间件tuxedo,数据库用的是Oracle,但由于不直接连接数据库,用中间件处理的方 ...
 - java:Hibernate框架3(使用Myeclipse逆向工程生成实体和配置信息,hql语句各种查询(使用hibernate执行原生SQL语句,占位符和命名参数,封装Vo查询多个属性,聚合函数,链接查询,命名查询),Criteria)
		
1.使用Myeclipse逆向工程生成实体和配置信息: 步骤1:配置MyEclipse Database Explorer: 步骤2:为项目添加hibernate的依赖: 此处打开后,点击next进入 ...
 - Hibernate框架之HQL查询与Criteria 查询的区别
		
Hibernate框架提供了HQL查询和Criteria 查询.下面对这两种查询分别做个例子.也好对这两种查询方法有个大概的了解.就用房屋信息表做例子,查询所有房屋信息. HQL语句查询所有房屋信息: ...
 - 一篇文章带你掌握主流基础框架——Spring
		
一篇文章带你掌握主流基础框架--Spring 这篇文章中我们将会介绍Spring的框架以及本体内容,包括核心容器,注解开发,AOP以及事务等内容 那么简单说明一下Spring的必要性: Spring技 ...
 - 详解Java的MyBatis框架中SQL语句映射部分的编写
		
这篇文章主要介绍了Java的MyBatis框架中SQL语句映射部分的编写,文中分为resultMap和增删查改实现两个部分来讲解,需要的朋友可以参考下 1.resultMap SQL 映射XML 文件 ...
 - PHP 设计模式 笔记与总结(2)开发 PSR-0 的基础框架
		
[PSR-0 规范的三项约定]: ① 命名空间必须与绝对路径一致 ② 类名的首字母必须大写 ③ 除入口文件外,其他".php"必须只有一个类(不能有可执行的代码) [开发符合 PS ...
 
随机推荐
- POJ——T3160 Father Christmas flymouse
			
Time Limit: 1000MS Memory Limit: 131072K Total Submissions: 3496 Accepted: 1191 缩点,然后每个新点跑一边SPFA ...
 - Rails + rabl
			
当我们使用rails generate scaffold的方式生成MVC的时候,rails会自己主动给我们生成一系列的文件,包含了怎样用json显示model的view.这样事实上默认了你的系统是一个 ...
 - 初识Oracle中的正则表达式
			
Oracle使用正则表达式离不开这4个函数: 1.regexp_like 2.regexp_substr 3.regexp_instr 4.regexp_replace
 - oracle多实例的启动与关闭
			
Oracle/oracle登录 1.启监听器 lsnrctl start 监听一般不需要动,如果机器重新启动的话需要将监听启动. 查看当前SID:echo $ORACLE_SID 2.启动数据库实例: ...
 - 洛谷——P1525 关押罪犯
			
https://www.luogu.org/problem/show?pid=1525 题目描述 S 城现有两座监狱,一共关押着N 名罪犯,编号分别为1~N.他们之间的关系自然也极不和谐.很多罪犯之间 ...
 - HDU 3072--Intelligence System【SCC缩点新构图 && 求连通全部SCC的最小费用】
			
Intelligence System Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Othe ...
 - Apache ZooKeeper Getting Started Guide 翻译
			
ZooKeeper 開始向导 開始:用zookeeper协调分布式程序 单例操作 管理zookeeper存储 连接zookeeper 执行zookeeper 以复制模式执行zookeeper 其他优化 ...
 - javascript进阶课程--第二章--对象
			
javascript进阶课程--第二章--对象 学习要点 理解面向对象的概念 掌握对象的创建方法 掌握继承的概念和实现方法 基本概念 对象究竟是什么?什么叫面向对象编程? 对象是从我们现实生活中抽象出 ...
 - 建堆是 O(n) 的时间复杂度证明。
			
建堆的复杂度先考虑满二叉树,和计算完全二叉树的建堆复杂度一样. 对满二叉树而言,第 \(i\) 层(根为第 \(0\) 层)有 \(2^i\) 个节点. 由于建堆过程自底向上,以交换作为主要操作,因此 ...
 - 洛谷 P3386 【模板】二分图匹配 Dinic版
			
题目背景 二分图 题目描述 给定一个二分图,结点个数分别为n,m,边数为e,求二分图最大匹配数 输入输出格式 输入格式: 第一行,n,m,e 第二至e+1行,每行两个正整数u,v,表示u,v有一条连边 ...