写hql语句与不写hql语句的区别?

写hql语句:书写HQL语句,所有的查询与投影的设计均使用HQL语句完成。

不写hql语句:没有任何查询语句,所有的查询与投影的设计使用面向对象格式完成。

二者选用的时机:

不写hql语句,有时比较方便,在不考虑复杂的查询的情况下,可以使用,此方法把某些Hibernate的方法封装起来,不灵活。

写hql语句,复杂的业务逻辑,建议使用,灵活方便。

以下通过俩种方法的对比来着重介绍一下hibernate不写hql的一种简单用法。

写hql语句:

具有丰富的灵活性,可以提供强大的查询功能。

如:String hql = “ from User “ ,查询所有的User实体类所对应的数据库字段。

Session session = this.getCurrentSession();

String hql = " from User ";

Query q = session.createQuery(hql);

List<User> users = q.list();

return users;

如:String hql= “ update User user set user.age=22 where user.age=12 ”;更新User实体类所对应的数据记录。

Session session = this.getCurrentSession();

String hql = " update User user set user.age=22 where user.age=12 ";

Query q = session.createQuery(hql);

q.uniqueResult();

return null;

如:String hql=” delete from User user where user.age=19 ”;  删除User实体类所对应的数据记录。

Session session = this.getCurrentSession();

String hql = " delete from User user where user.age=? ";

Query q = session.createQuery(hql);

q.setParameterList("age", age);

q.executeUpdate();

return null;

不写hql语句:

查询User实体类所对应的数据库字段数据,可以用一下方法:

//得到User对应的数据中的所有的数据记录

public List<User> getDepList()throws Exception{

DetachedCriteria dc =  DetachedCriteria.forClass(User.class);

return getHibernateTemplate().find(dc);

}

DetachedCriteria 为离线查询。

若要构造相应的条件查询,可以如下所示:

public List<User> getDepList()throws Exception{

DetachedCriteria dc =  DetachedCriteria.forClass(User.class);

if(user != null){

if(user .getName()!=null && !user .getName().equals("")){

dc.add(Restrictions.ilike("name", user.getName(), MatchMode.ANYWHERE));

}

if(user.getTele()!=null && !user.getTele().equals("")){

dc.add(Restrictions.ilike("tele",user.getTele(), MatchMode.ANYWHERE));

}

}

return getHibernateTemplate().find(dc);

}

Restrictions为投影查询,里面封装了各种查询条件,如上面,ilike()表示模糊查询,里面的三个参数,分别代表“数据库字段”、“所对应的字段值”、“模糊查询匹配模式”。

另外模板中封装了好多关于查询条件的方法:

若要增加一条记录,可以参照以下方法:

getHibernateTemplate().save(user);

直接用模板保存一个实体类,在此之前应把数据封装到user实体类中。

另外模板中还封装了其他的一些save类似的方法:

若要修改表中某条记录,可以参照以下方法:

getHibernateTemplate().update(user);

同样用模板直接更新即可。

另外模板中还有封装了一些和更新有关的类似的方法:

若要删除表中的某条记录,可以参照如下的方法:

getHibernateTemplate().delete(user);

同样直接使用模板即可完成。

另外模板中还有封装了一些和删除有关的类似的方法:

由于知识有限,写的比较单薄,望指导赐教。

Hibernate写hql语句与不写hql语句的区别?的更多相关文章

  1. 用Hibernate框架把hql生成可执行的sql语句-Oracle方言

    引言:为什么这样的需求,源自公司项目需要,公司的项目使用java的struts2+spring2.5+oracle中间件tuxedo,数据库用的是Oracle,但由于不直接连接数据库,用中间件处理的方 ...

  2. Hibernate 问题,在执行Query session.createQuery(hql) 报错误

    在配置文件中加入 <prop key="hibernate.query.factory_class">org.hibernate.hql.internal.classi ...

  3. hibernate框架学习之数据查询(HQL)

    lHibernate共提供5种查询方式 •OID数据查询方式 •HQL数据查询方式 •QBC数据查询方式 •本地SQL查询方式 •OGN数据查询方式 OID数据查询方式 l前提:已经获取到了对象的OI ...

  4. hibernate对连接池的支持和HQL查询

    hibernate对连接池的支持 连接池, 作用: 管理连接:提升连接的利用效率! 常用的连接池: C3P0连接池 Hibernate 自带的也有一个连接池,且对C3P0连接池也有支持! 只维护一个连 ...

  5. Hibernate插入、查询、删除操作 HQL

    Hibernate的所有的操作都是通过Session完成的. 基本步骤如下: 1:通过配置文件得到SessionFactory: SessionFactory sessionFactory=new C ...

  6. 转>>在同一个sql语句中如何写不同条件的count数量

    今天在做Portal中的Dashboard展现的时候,需要对多个统计字段做展现,根据我现在的掌握水平,我只能在sql调用构建器中实现一种sql语 句返回的resultSet做展现.没有办法,只能从数据 ...

  7. 向已写好的多行插入sql语句中添加字段和值

    #region 添加支款方式--向已写好的多行插入sql语句中添加字段和值 public int A_ZhifuFS(int diqu) { ; string strData = @"SEL ...

  8. 在数据库里面有这么一个表:用m代表男,用f代表女,现在我要输出格式为中文的:男和女,sql语句该怎么写

    在数据库里面有这么一个表:用m代表男,用f代表女,现在我要输出格式为中文的:男和女, sql语句该怎么写 select  case sex when 'm' then '男' else '女'   a ...

  9. SQL语句利用日志写shell

    outfile被禁止,或者写入文件被拦截: 在数据库中操作如下:(必须是root权限) show variables like '%general%'; #查看配置 set global genera ...

随机推荐

  1. Explosion at Cafebazaar

    Explosion at Cafebazaar 时间限制: 1 Sec  内存限制: 128 MB 题目描述 You are an engineer at Cafebazaar and your sp ...

  2. BZOJ4726: [POI2017]Sabota?

    $n \leq 500000$的树,开始有一个点是坏的,如果一个子树中坏点比例(不包括根节点)超过x那这整棵子树就会变坏,问最坏情况下不超过$K$个坏点的情况下$x$最小是多少. 被坑成傻逼.. 可以 ...

  3. gridview和detailsview的完美结合运用实现增删改

    原文发布时间为:2008-07-24 -- 来源于本人的百度文章 [由搬家工具导入] 1、因Gridview中没有增加记录,所以应利用datalistview或formview来弥补。 2、因为det ...

  4. MVC 上传文件的方法

    这两天又开始研究MVC了,期间断断续续已经搞了好久了,可是都没坚持下来.囧!这次一定坚持搞出来一个名堂. 废话少说,直接上代码. 前台引擎采用Razor @model System.Web.HttpP ...

  5. hdu3315 /最大权最佳匹配(最大权下尽量不改变次序)(有权田忌赛马类问题)/费用流

    题意:2个人比赛,每场比赛有得分,每场每人派一支圣兽( brute ,字典翻译为畜生,感觉这里不太符╮(╯▽╰)╭),有攻击力和血条...一堆规则... 合理安排,让1号人获得最大分数,并尽量不要改变 ...

  6. jqeury设置元素屏幕居中

    jQuery.fn.center = function () { this.css(“position”,”absolute”); this.css(“top”, ( $(window).height ...

  7. ZOJ - 4016 Mergeable Stack (STL 双向链表)

    [传送门]http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=4016 [题目大意]初始有n个空栈,现在有如下三种操作: (1) ...

  8. Go -- 通过GOTRACEBACK生成程序崩溃后core文件的方法(gcore gdb)

    写一个错误的c程序   package dlsym import "testing" func Test_intercept(t *testing.T) { Intercept(& ...

  9. MVP模式是你的救命稻草吗?

    为什么要学习架构? 不管是MVC还是MVP,亦或则其他架构,它们的设计目的都是为了达到编码的最高境界,那就是:低藕合,高复用,易测试,好维护. 而要达到这个终极目标,首先要理解的是每个部分各自负责些什 ...

  10. BMP文件的读取与显示

    有三个函数能够完毕这一功能 1.BitBlt    BitBlt 用于从原设备中复制位图到目标设备 void CMFCApplication1View::OnDraw(CDC* pDC) { CMFC ...