上篇讲述了最基本的实体类,本篇接着讲述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)
分享到:
相关推荐
hibernate-HQL语句大全
"Hibernate-HQL语句多对多写法" Hibernate 是一个流行的 Java 持久层框架,它提供了强大的对象关系映射(ORM)功能,使得开发者可以方便地与数据库交互。但是,在使用 Hibernate 时,我们经常会遇到多对多关系的...
Hibernate是一款强大的对象关系映射框架,它极大地简化了Java开发人员在数据库操作中的工作。在Hibernate中,HQL(Hibernate Query Language)是专为ORM设计的一种面向对象的查询语言,它允许开发者以类和对象的方式...
HQL的全称是?...HQL语句为:select jd.jdid,jd.jd from TblJd jd。怎样获得并显示查询结果? 使用'?'做占位符的参数查询,怎样设置参数的值? 命名参数查询的语法是? 怎样创建Criteria查询对象?
### Hibernate 查询语句 -- HQL #### 概述 Hibernate 是一个开源的对象关系映射 (ORM) 框架,它允许开发人员将 Java 对象映射到数据库表中的记录,从而简化了数据访问逻辑。在 Hibernate 中,执行查询操作的主要...
标题中的“Hibernate-HQL-QBC-QBE”涵盖了四个重要的Java持久化框架Hibernate中的概念,分别是Hibernate Query Language(HQL)、Query By Criteria(QBC)、Query By Example(QBE)以及相关的库文件。以下是对这些...
【标题】"hibernate-hql-lucene-1.0.1.Final.zip" 提供的是一个关于Hibernate HQL与Lucene集成的开源项目版本,主要用于在Java应用程序中实现高效、复杂的全文搜索功能。 【描述】"pact-jvm.zip,pact模型" 指的是...
2. 避免在HQL中使用SQL函数:尽量用Hibernate提供的函数,以确保跨数据库兼容性。 3. 优化查询性能:合理设计数据库索引,避免全表扫描,尽量减少JOIN操作。 总之,Hibernate-HQL是Java开发中处理数据库查询的重要...
Hibernate 查询语言 HQL(Hibernate Query Language)是Hibernate框架提供的一种面向对象的查询语言,它是对SQL的封装,使得开发者可以使用面向对象的方式来处理数据库查询,避免了直接操作SQL带来的复杂性和对象与...
【标题】"hibernate-hql-testing-1.0.0.Alpha5.zip" 提供的是Hibernate框架的一个测试工具包,专注于HQL(Hibernate Query Language)的测试。Hibernate是Java领域中广泛使用的对象关系映射(ORM)框架,它允许...
hibernate3-hql.jar .
Hibernate框架Hql语句in中带参数的写法 Hibernate框架中,在使用HQL语句时,需要传递参数,而在HQL语句中使用in关键字时,需要特别注意参数的传递方式。在本文中,我们将讨论如何在HQL语句中使用in关键字带参数的...
Struts、Spring和Hibernate是Java开发中常用的三大框架,它们分别负责不同的职责:Struts作为MVC(模型-视图-控制器)框架处理请求和响应,Spring提供了依赖注入和事务管理,而Hibernate则是对象关系映射(ORM)框架...
HQL(Hibernate Query Language)是Hibernate框架中的查询语言,它提供了面向对象的方式来进行数据库查询。HQL语法接近于SQL但又有所不同,它允许开发者以面向对象的方式来表达查询逻辑,使得查询更加直观且易于理解...
HQL语句 HQL语句 HQL语句 HQL语句 HQL语句
hibernate查询-hql等教程,对于学习hibernate有很好的帮助。
在Spring框架中,Hibernate Query Language(HQL)是一种强大的工具,用于执行对象关系映射(ORM)查询。HQL是面向对象的查询语言,与SQL类似但更专注于处理Java对象而不是数据库表。在这个名为“Spring--HQL-chaxun...
**hibernate-HQL用例** Hibernate 是一个强大的Java持久化框架,它简化了与关系数据库之间的交互。HQL(Hibernate Query Language)是Hibernate提供的面向对象的查询语言,类似于SQL,但更贴近Java对象的思维模式。...
HQL是一种面向对象的查询语言,用于在Hibernate框架中执行数据检索任务。它允许开发人员以一种接近Java语言的方式进行数据库操作,从而简化了数据访问层的复杂度。 ### 1. from子句 `from`子句是HQL语句的基础,...
Hibernate HQL,全称为Hibernate Query Language,是Hibernate框架中用于操作对象关系映射(ORM)的查询语言。它类似于SQL,但设计目的是针对Java对象,而不是数据库表。HQL允许开发者以面向对象的方式编写查询,...