sql条件查询有没有比较优雅的写法?除了字符串拼接

boluoy 2017-11-30 09:37:03
ORM框架目前是用的hibernate,
数据库里有很多表,简单查询用 criteria加上类模版不用一个个自己写sql语句
但是如果要用inner join结合where之类的复杂查询好像criteria不行。目前我是字符串拼接出来的
如果有很多个表都有这种复杂查询的需要感觉一个个字符串拼接很麻烦,有没有优雅一点的写法,
hibernate有一个setparameter是可以设置参数的,但是要先写好要查哪些参数,感觉也不方便。
/**
* 根据查询HQL与参数列表创建Query对象. 与find()函数可进行更加灵活的操作.
*
* @param values
* 数量可变的参数,按顺序绑定.
*/
public Query createQuery(final String queryString, final Object... values) {
Assert.hasText(queryString, "queryString不能为空");
Query query = getSession().createQuery(queryString);
if (values != null) {
for (int i = 0; i < values.length; i++) {
query.setString(i, (String) values[i]);
}
}
return query;
}
...全文
236 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
zzxiaoma 2017-11-30
  • 打赏
  • 举报
回复
一般建类的时候就存在关联关系,如果查询的在类里面体现不出来,我觉得最好还是写hql
  • 打赏
  • 举报
回复
这已经不错了。。。要是用c一类的语言,,,还得处理内存啥的,,不是更麻烦?

62,615

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧