hql Hibernate.gethibernatetemplate()
1. find(String hql); //普通查询
示例:this.gethibernateTemplate().find("from User");
2. find(String hql,Object value);//一个查询条件
示例:this.gethibernateTemplate().find("from User u where u.name=?","test");
3. find(String hql,Object[] values);// 多个查询条件
示例:this.gethibernateTemplate().find("from User u where u.name=? and u.pwd=?",new String[]{"test","123"});
4. findByExample(Object exampleEntity,int firstResult, int maxResults)//分页使用
示例:
User user= new User(); u.setActive("Active");
List list=this.getHibernateTemplate().findByExample(user,firstResult,maxResults);
查询结果:状态为Active的用户(对象从0到20 计数)
5. findByNamedParam(String hql,String paramName,Object value); //一个查询条件
示例:
hql="from User u where u.name=:parName ";
paramName= "parName";
value="bb"
List list = this.getHibernateTemplate.findByNamedParam(hql,paramName,value);
查询结果:姓名为bb的用户
6. findByNamedParam(String queryString , String[] paramName , Object[] value) //多个查询条件
示例:
hql="from User u where u.name=:myname and u.pwd =:mypwd ";
String[] paramName= new String[]{"myname","mypwd"};
Sring[] value=new Strign[]{"bb","123"};
List list = this.getHibernateTemplate.findByNamedParam(hql,paramName,value);
查询结果:姓名为bb密码为123的用户
7.分页HQL示例
public List excuteHqlPage(final String hqlStr, final int startRow,final int rowCount) throws DaoException {
List<Object[]> list;
try {
list = getHibernateTemplate().executeFind(new HibernateCallback() {
public Object doInHibernate(Session session)
throws HibernateException, SQLException {
org.hibernate.Query query = (org.hibernate.Query) session.createQuery(hqlStr);
query.setFirstResult(startRow);// 定义从第几条开始查询
query.setMaxResults(rowCount);// 定义返回的记录数
List list = query.list();
return list;
}
});
} catch (Exception e) {
throw new DaoException(DaoException.ERRORCODE_EXCUTEHQL);
}
return list;
}
8. 根据HQL/SQL 查询
public List queryByHql(final String hql, final Object[] prams,final String sql) {
return (List) getHibernateTemplate().execute(new HibernateCallback(){
public Object doInHibernate(Session session)
throws HibernateException, SQLException {
if(hql!=null && hql.length()>0){
Query query=session.createQuery(hql);
if(prams!=null && prams.length>0){
for(int i=0;i<prams.length;i++){
query.setParameter(i,prams[i]);
}
}
return query.list();
}else{
SQLQuery sqlquery=session.createSQLQuery(sql);
return sqlquery.list();
}
}
});
}
9. 保存/更新
public String saveOrUpdateObject(ISuperVO vo) throws DaoException {
try {
String id = null;
if (StringUtil.isEmpty(vo.getPid())) {
getHibernateTemplate().save(vo);
} else {
getHibernateTemplate().merge(vo);
}
id = vo.getPid();
return id;
} catch (Exception e) {
e.printStackTrace();
}
}
10. getHibernateTemplate().delete(vo); //删除
11. 根据条件删除
public Integer deleteObjectsByWherePart(final Class voClass,final String wherePart, final Object[] parmaters)throws DaoException {
try {
Integer count = (Integer) getHibernateTemplate().execute( new HibernateCallback() {
public Object doInHibernate(Session session)throws HibernateException, SQLException {
Integer coun = null;
String hql = "delete from " + voClass.getName()+ " where 1=1 ";
if (wherePart != null && wherePart.trim().length() > 0) {
hql = hql + " and " + wherePart;
}
Query query = session.createQuery(hql);
Object obj = null;
if (parmaters != null && parmaters.length > 0) {
for (int i = 0; i < parmaters.length; i++) {
obj = parmaters[i];
query.setParameter(i, obj);
}
}
coun = query.executeUpdate();
return coun;
}
});
return count;
} catch (Exception e) {
e.printStackTrace();
}
}
hql Hibernate.gethibernatetemplate()的更多相关文章
- paip.取当天记录的方法sql跟hql hibernate
paip.取当天记录的方法sql跟hql hibernate #------两个方法...函数法和日期计算法.. 函数法: DATEDIFF(d,createTime,GETDATE())=0 / ...
- HQL: Hibernate查询语言
HQL: Hibernate查询语言 Hibernate配备了一种非常强大的查询语言,这种语言看上去很像SQL.但是不要被语法结构 上的相似所迷惑,HQL是非常有意识的被设计为完全面向对象的查询,它可 ...
- hql(Hibernate Query Language)
1.Criteria查询对查询条件进行了面向对象封装,符合编程人员的思维方式,不过HQL(Hibernate Query Language)查询提供了更加丰富的和灵活的查询特性,因此Hibernate ...
- 类型:。net;问题:HQL;结果:HQL: Hibernate查询语言
HQL: Hibernate查询语言 Hibernate配备了一种非常强大的查询语言,这种语言看上去很像SQL.但是不要被语法结构 上的相似所迷惑,HQL是非常有意识的被设计为完全面向对象的查询,它可 ...
- Hibernate查询(HQL——Hibernate Query Language)
HQL查询 HQL提供了是十分强大的功能,它是针对持久化对象,用取得对象,而不进行update,delete和insert等操作.而且HQL是面向对象的,具备继承,多态和关联等特性. from子句: ...
- 常用HQL(Hibernate Query Language)查询
查询一个对象(实体类必须有一个不带参数的构造方法) 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 @Test public void test01() ...
- Hibernate之HQL查询的一些例子
Hibernate配备了一种非常强大的查询语言,就是HQL(hibernate query language),HQL看上去很像sql,但只是语法结构上相似,HQL是一种面向对象的查询,他可以理解继承 ...
- SSH整合报错:org.hibernate.hql.internal.ast.QuerySyntaxException: User is not mapped[......]
非常诡异的报错,信息如下:org.hibernate.hql.internal.ast.QuerySyntaxException: User is not mapped [select count(* ...
- Hibernate学习-Hibernate查询语言HQL
HQL(Hibernate Query Language)Hibernate查询语言,语法类似于SQL,可以直接使用实体类及属性. 使用HQL 可以避免使用JDBC 查询的一些弊端 不需要再编写繁复的 ...
随机推荐
- 《Android 编程权威指南》读书总结
1.当一段代码被多次使用,可将这段代码封装成一个抽象类,以后再要用到该段代码时,直接extends(继承)这个抽象类. 2.SDK版本向后兼容,即在SDK发布后推出的Android版本都可以使用该SD ...
- 通过python-libvirt管理KVM虚拟机 代码实现
初步代码 <span style="font-size:18px;">''''' Work with virtual machines managed by libvi ...
- 不要问我有多懒,写个脚本跑django
写django的都知道,要跑起django测试环境,只需要 python manage.py runserver 就可以了,但是时间一长,就觉得敲这个命令太浪费时间了,而我又是个懒人. 同事用的是ct ...
- [转]layDate显示默认时间
原文地址:https://blog.csdn.net/u011870547/article/details/72540074 jsp: <div class="form-group&q ...
- [转]jquery.validate.js表单验证
原文地址:https://www.cnblogs.com/si-shaohua/p/3780321.html 一.用前必备官方网站:http://bassistance.de/jquery-plugi ...
- plot sin示意图(隐藏刻度,自定义刻度)
plot sin示意图(隐藏刻度,自定义刻度) 隐藏坐标轴刻度 自定义坐标轴刻度 Code #!/usr/bin/env python # -*- coding: utf-8 -*- import n ...
- <[完整版]中国式价值投资>读书笔记
注重本金安全 股票价格的高级与股票的贵贱没有任何关系 同股同权的应该买便宜的 买未来有可能变得更大的优秀公司股票,只有他们的股价才有可能有持续向上的原动力 如果绝大多数投资者对股票高市盈率不是拒绝而是 ...
- [转]css选择器优先级深入理解
转载自:http://www.jb51.net/css/67029.html 一.基础选择器 css基础选择器有标签选择器.类选择器.id选择器.通用选择器 1.标签选择器 每个html页面都由很多个 ...
- android开发(25) - 推送的实现,使用百度云推送
什么叫推送? 中文名称:推送 英文名称:push 定义:描述因特网内容提供者和因特网用户之间工作方式的术语.“推送”指因特网内容提供者定期向预订用户“提供”数据. 项目中有可能会用到推送.如果自己写一 ...
- PCL中分割方法的介绍(3)
(3)上两篇介绍了关于欧几里德分割,条件分割,最小分割法等等还有之前就有用RANSAC法的分割方法,这一篇是关于区域生成的分割法, 区 域生长的基本 思想是: 将具有相似性的像素集合起来构成区域.首先 ...