写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. 酒厂选址(codevs 1507)

    题目描述 Description Abstinence(戒酒)岛的居民们酷爱一种无酒精啤酒.以前这种啤酒都是从波兰进口,但今年居民们想建一个自己的啤酒厂.岛上所有的城市都坐落在海边,并且由一条沿海岸线 ...

  2. 集合 Properties 的 简单例子(Spring)

    Java代码: package com.ioc; import java.util.Properties; public class Student { private String name; pr ...

  3. BZOJ4726: [POI2017]Sabota?

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

  4. C# 判断上传图片是否被PS修改过的方法

    今天在网上发现一个判断图片是否被Photoshop修改过的方法.发现还不错,呵呵.摘录下来. 讲下基本的原理:其实每张被photoshop修改过的图片都会有Adobe Photoshop这样的字样在图 ...

  5. python常用模块详解(一)

    一.简介 模块是一个保存了Python代码的文件.模块能定义函数,类和变量.模块里也能包含可执行的代码 模块分为三种: 自定义模块 内置标准模块 开源模块(第三方) 自定义模块: 模块导入 impor ...

  6. msp430项目编程50

    msp430综合项目---gsm无线采集传输平台系统50 1.电路工作原理 2.代码(显示部分) 3.代码(功能实现) 4.项目总结

  7. (25)python urllib库

    urllib包包含4个模块,在python3里urllib导入要用包名加模块名的方式. 1.urllib.request 该模块主要用于打开HTTP协议的URL import urllib.reque ...

  8. python入门示例程序

    该实例是raspi和dsp电机运动控制板的串口uart通信: import serial class SerialHandler(): ''' raspi serial for communicati ...

  9. 【面试 AOP】【第八篇】AOP的问题

    1.AOP的原理以及应用场景 面向切面编程,不修改原有代码逻辑的情况下进行逻辑增强. 使用场景:短信业务,restful返回统一响应体等等. ============================= ...

  10. Mathematica 表达式求值

    表达式是变量之间的运算关系.表达式求值就是对变量赋值并运算出结果的过程. 针对于Mathematica中的表达式.有两种方法获得其值. 一是对对应的变量直接赋值.这样对应的表达式在调用时便会直接运算得 ...