hibernate中.常见的hql查询语句
hql是非常有意识的被设计为完全面向对象的查询
基本规则:
1.hql语法类似于sql,但它后面跟的不是表名和字段名,而是类名和属性名
2.hql大小写不敏感.但是设计java类名,包名,属性名时大小写敏感.
public void test1(){ //重要
Session session = HibUtil.getSession();
Transaction tx =session.beginTransaction();
Query query =session.createQuery("from Emp e");
List<Emp> empList = query.list();
for(Emp e:empList){
System.out.println(e.getEname());
}
tx.commit();
session.close();
}
public void test2(){ //单个对象 重要
Session session = HibUtil.getSession();
Transaction tx =session.beginTransaction();
Query query =session.createQuery("select count(*) from Emp e");//集合函数查询
Long n = (Long) query.uniqueResult();
System.out.println(n);
tx.commit();
session.close();
}
public void test3(){ //单个对象 重要
Session session = HibUtil.getSession();
Transaction tx =session.beginTransaction();
Query query =session.createQuery("from Emp e where e.empno=7369");
Emp emp = (Emp) query.uniqueResult();
System.out.println(emp.getEname());
tx.commit();
session.close();
}
public void test4(){ //Object[] 次重要
Session session = HibUtil.getSession();
Transaction tx =session.beginTransaction();
Query query =session.createQuery("select e.empno,e.ename from Emp e ");
List<Object[]> list =query.list();
for(Object[] obj:list){
System.out.println(obj[0]+"-->"+obj[1]);
}
tx.commit();
session.close();
}
public void test5(){ //map 次重要
Session session = HibUtil.getSession();
Transaction tx =session.beginTransaction();
Query query =session.createQuery("select new map(e.empno as empno,e.ename as ename) from Emp e ");
List<Map<String,Object>> list =query.list();
for(Map<String,Object> map:list){
System.out.println(map.get("empno")+"-->"+map.get("ename"));
}
tx.commit();
session.close();
}
public void test6(){ //对象 次重要
Session session = HibUtil.getSession();
Transaction tx =session.beginTransaction();
Query query =session.createQuery("select new com.cdsxt.hib.vo.EmpVo(e.empno,e.ename) from Emp e ");//投影查询
List<EmpVo> list =query.list();
for(EmpVo emp:list){
System.out.println(emp.getEmpno()+"-->"+emp.getEname());
}
tx.commit();
session.close();
}
public void test7(){ //where条件 重要
Session session = HibUtil.getSession();
Transaction tx =session.beginTransaction();
// Query query =session.createQuery("from Emp e where e.job=?");
// query.setParameter(0, "CLERK");//?是从0开始的
Query query =session.createQuery("from Emp e where e.job=:job");
query.setParameter("job", "CLERK");
List<Emp> list =query.list();
for(Emp emp:list){
System.out.println(emp.getEmpno()+"-->"+emp.getEname());
}
tx.commit();
session.close();
}
public void test8(){ //where条件 重要
Session session = HibUtil.getSession();
Transaction tx =session.beginTransaction();
Query query =session.createQuery("from Emp e where e.dept.deptno=:deptno");
query.setParameter("deptno", 10);
List<Emp> list =query.list();
for(Emp emp:list){
System.out.println(emp.getEmpno()+"-->"+emp.getEname()+"-->"+emp.getDept().getDname());
}
tx.commit();
session.close();
}
public void test9(){ //where条件 重要
Session session = HibUtil.getSession();
Transaction tx =session.beginTransaction();
Query query =session.createQuery("from Emp e left outer join e.dept"); //hql会自动匹配e.deptno=dept.deptno
query.list();
tx.commit();
session.close();
}
public void test10(){ //where条件 重要
Session session = HibUtil.getSession();
Transaction tx =session.beginTransaction();
SQLQuery sqlQuery=session.createSQLQuery("select * from Emp e where e.ename like ?");
sqlQuery.setParameter(0, "%A%");
sqlQuery.addEntity(Emp.class);
List<Emp> empList = sqlQuery.list();
for(Emp emp:empList){
System.out.println(emp.getEmpno()+"-->"+emp.getEname()+"-->"+emp.getDept().getDname());
}
tx.commit();
session.close();
}

hibernate中.常见的hql查询语句的更多相关文章
- J2EE进阶(十七)Hibernate中常用的HQL查询方法(getHibernateTemplate())
J2EE进阶(十七)Hibernate中常用的HQL查询方法(getHibernateTemplate()) 当我们使用Hibernate进行数据的CRUD操作时,利用模版进行操作不失为一种方法. ...
- Hibernate HQL查询语句总结
Hibernate HQL查询语句总结 1. 实体查询:有关实体查询技术,其实我们在先前已经有多次涉及,比如下面的例子:String hql="from User user ";L ...
- hibernate的hql查询语句总结
这篇随笔将会记录hql的常用的查询语句,为日后查看提供便利. 在这里通过定义了三个类,Special.Classroom.Student来做测试,Special与Classroom是一对多,Class ...
- HQL语句中数据类型转换,及hibernate中createQuery执行hql报错
一.HQL语句中数据类型转换: 我们需要从数据库中取出序号最大的记录,想到的方法就是使用order by子句进行排序(desc倒序),然后取出第一个对象,可是当初设计数据库时(我们是在原来的数据库的基 ...
- Hibernate中的多表查询及抓取策略
1.Hibernate中的多表查询 1.1SQL中的多表查询 [交叉连接] select * from A,B; [内连接] 显示内连接:inner join(inner 可以省略) Select * ...
- Hibernate中常见的异常处理
本文引自:http://www.blogjava.net/sy1214520/archive/2008/10/21/235667.html 本文总结Hibernate中常见的异常. 1. net.sf ...
- getHibernateTemplate()(Spring中常用的hql查询方法)
Spring中常用的hql查询方法(getHibernateTemplate()) --------------------------------- 一.find(String queryStrin ...
- 【hql】spring data jpa中 @Query使用hql查询 问题
spring data jpa中 @Query使用hql查询 问题 使用hql查询, 1.from后面跟的是实体类 不是数据表名 2.字段应该用实体类中的字段 而不是数据表中的属性 实体如下 hql使 ...
- Hibernate学习之hql查询语句
* 页面上数据的字段和数据库中字段差不多,这个时候,采用迫切连接 结构比较好,如果页面上的字段很少,要按照需求加载数据,采用带构造函数的select查询 实例讲解:转自:http://www.cn ...
随机推荐
- SVN 环境搭建 需要注意的地方
一. 服务器上安装的软件: 先 安装 Subversion 下载的地址:http://www.sliksvn.com/en/download 安装 TortoiseSVN 下载地址:http:/ ...
- Maven 私服 Nexus 权限控制
Nexus 用户 Nexus 预定义了三个用户,这三个用户对应了三个权限级别: admin:该用户拥有对Nexus服务的完全控制,默认密码为 admin123,以下为admin用户的角色树 deplo ...
- ES(4): ES Cluster Security Settings
目录: ES安全事件回顾 ES集群安全建议 安全访问配置 license更新 ES安全事件回顾 下面是白帽汇监测到针对全球使用广泛的全文索引引擎Elasticsearch的勒索事件: 2017年1月1 ...
- android开发常用组件【持续更新中。。。】
UI相关 图片 Android-Universal-Image-Loader:com.nostra13.universalimageloader:异步加载.缓存.显示图片 ImageLoader:co ...
- 小峰servlet/jsp(7)jstl国际化标签库、sql标签库等
一.jstl国际化标签库: fmt:setLocale 设定用户所在的区域: fmt:formatDate 对日期进行格式化 fmt:requestEncoding 设置所有的请求编码; fmt: ...
- linux如何查看系统是多少位的?64 OR 32
1.可以用命令“getconf LONG_BIT”查看, 如果返回的结果是32则说明是32位,返回的结果是64则说明是64位. 2.此外还可以使用命令“uname -a”查看, 输出的结果中,如果有x ...
- (转)Win7 64位系统下 Retional rose 2003 安装及破解
网上关于Retional rose 2003安装和破解的文章比较多,这里,我结合自己的亲身体验,和大家分享一下win7 旗舰版 64位系统下Retional rose 2003(下面简称rose200 ...
- 自己写的一个jQuery分页插件
;(function($){ $.fn.extend({ pageList: function (json) { function PageList() { this.initHtml = " ...
- 自己根据js的兼容封装了一个小小的js库
var gys = function () { } //oParent父节点 //获取所有的子元素 gys.prototype.getElementChildren = function (oPare ...
- Java Internet
网络通信: 网络通信三要素: IP 协议 端口 TCP: 建立连接,发送速度慢 三次握手协议 UDP: 不需要建立连接,发送速度快 安全性低 a) 使用UDP实现数据的发送 1 创建Socket端点实 ...