Hibernate写hql语句与不写hql语句的区别?
写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语句的区别?的更多相关文章
- 用Hibernate框架把hql生成可执行的sql语句-Oracle方言
引言:为什么这样的需求,源自公司项目需要,公司的项目使用java的struts2+spring2.5+oracle中间件tuxedo,数据库用的是Oracle,但由于不直接连接数据库,用中间件处理的方 ...
- Hibernate 问题,在执行Query session.createQuery(hql) 报错误
在配置文件中加入 <prop key="hibernate.query.factory_class">org.hibernate.hql.internal.classi ...
- hibernate框架学习之数据查询(HQL)
lHibernate共提供5种查询方式 •OID数据查询方式 •HQL数据查询方式 •QBC数据查询方式 •本地SQL查询方式 •OGN数据查询方式 OID数据查询方式 l前提:已经获取到了对象的OI ...
- hibernate对连接池的支持和HQL查询
hibernate对连接池的支持 连接池, 作用: 管理连接:提升连接的利用效率! 常用的连接池: C3P0连接池 Hibernate 自带的也有一个连接池,且对C3P0连接池也有支持! 只维护一个连 ...
- Hibernate插入、查询、删除操作 HQL
Hibernate的所有的操作都是通过Session完成的. 基本步骤如下: 1:通过配置文件得到SessionFactory: SessionFactory sessionFactory=new C ...
- 转>>在同一个sql语句中如何写不同条件的count数量
今天在做Portal中的Dashboard展现的时候,需要对多个统计字段做展现,根据我现在的掌握水平,我只能在sql调用构建器中实现一种sql语 句返回的resultSet做展现.没有办法,只能从数据 ...
- 向已写好的多行插入sql语句中添加字段和值
#region 添加支款方式--向已写好的多行插入sql语句中添加字段和值 public int A_ZhifuFS(int diqu) { ; string strData = @"SEL ...
- 在数据库里面有这么一个表:用m代表男,用f代表女,现在我要输出格式为中文的:男和女,sql语句该怎么写
在数据库里面有这么一个表:用m代表男,用f代表女,现在我要输出格式为中文的:男和女, sql语句该怎么写 select case sex when 'm' then '男' else '女' a ...
- SQL语句利用日志写shell
outfile被禁止,或者写入文件被拦截: 在数据库中操作如下:(必须是root权限) show variables like '%general%'; #查看配置 set global genera ...
随机推荐
- 品酒大会 BZOJ 4199
品酒大会 [问题描述] [输入格式] [输出格式] [样例输入] 10ponoiiipoi 2 1 4 7 4 8 3 6 4 7 [样例输出] 45 56 10 56 3 32 0 0 0 0 0 ...
- Laravel 静态资源管理
<link rel="stylesheet" href="{{ asset('bootstrap/css/bootstrap.min.css') }}" ...
- 带你学Node系列之express-CRUD
前言 hello,小伙伴们,我是你们的pubdreamcc,本篇博文出至于我的GitHub仓库node学习教程资料,欢迎小伙伴们点赞和star,你们的点赞是我持续更新的动力. GitHub仓库地址:n ...
- mysql索引底层的数据结构和算法
1. 为什么要用索引 索引在MySQL中也叫做“键”,是存储引擎用于快速找到记录的一种数据结构.索引对于良好的性能非常关键,尤其是当表中的数据量越来越大时,索引对于性能的影响愈发重要. 索 ...
- Google代码风格配置文件(Java)(IDEA/Eclipse)
官网:http://www.cnblogs.com/EasonJim/p/7837474.html 下载: 安装: IDEA/Eclipse导入相应文件即可. 说明: Google代码风格文件的缩进是 ...
- 【lombok】使用lombok注解,在代码编写过程中可以调用到get/set方法,但是在编译的时候无法通过,提示找不到get/set方法
错误如题:使用lombok注解,在代码编写过程中可以调用到get/set方法,但是在编译的时候无法通过,提示找不到get/set方法 报错如下: 解决方法: 1.首先查看你的lombok插件是否下载安 ...
- java平台利用jsoup开发包,抓取优酷视频播放地址与图片地址等信息。
/******************************************************************************************** * aut ...
- docker (2)---存储、网络(利用docker容器上线静态网站)
一.docker底层依赖的核心技术 1.命名空间 (Namespaces) 2.控制组 (Control Groups) 3.联合文件系统 (Union File System) 4.Linux 虚拟 ...
- HashMap源代码学习笔记
HashMap的底层主要是基于数组和链表来实现的,它之所以有相当快的查询速度主要是由于它是通过计算散列码来决定存储的位置. HashMap中主要是通过key的hashCode来计算hash值的 ...
- CA与数字证书的自结
1.CA CA(Certificate Authority)是数字证书认证中心的简称,是指发放数字证书.管理数字证书.废除数字证书的权威机构. 2.数字证书 如果向CA申请数字证书的单位为A.则他申请 ...