hibernate学习
Posted 寒潭渡鹤影
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了hibernate学习相关的知识,希望对你有一定的参考价值。
Hibernate查询方式
1 对象导航查询
(1)根据id查询某个客户,再查询这个客户里面所有的联系人
2 OID查询
(1)根据id查询某一条记录,返回对象
3 hql查询
(1)Query对象,写hql语句实现查询
4 QBC查询
(1)Criteria对象
5 本地sql查询
(1)SQLQuery对象,使用普通sql实现查询
重点掌握前四种方式。
对象导航查询
1 查询某个客户里面所有联系人过程,使用对象导航实现
2 代码
//根据cid=1客户,再查询这个客户里面所有联系人 Customer customer = session.get(Customer.class, 1); //再查询这个客户里面所有联系人 //直接得到客户里面联系人的set集合 Set<LinkMan> linkman = customer.getSetLinkMan(); System.out.println(linkman.size());
OID查询
1 根据id查询记录
(1)调用session里面的get方法实现
//根据cid=1客户,再查询这个客户里面所有联系人 Customer customer = session.get(Customer.class, 1);
HQL查询
1 hql:hibernate query language,hibernate提供一种查询语言,hql语言和普通sql很相似,最大的区别是:普通sql操作数据库表和字段,hql操作实体类和属性。
2 常用hql语句
(1)查询所有:from 实体类名称
(2)条件查询:from 实体类名称 where 属性名称=?
(3)排序查询:from 实体类名称 order by 实体类属性名称 asc/desc
3 使用hql查询操作的时候,使用Query对象
(1)创建Query对象,写hql语句
(2)调用query对象里面的方法得到结果
查询所有
1 查询所有客户记录
(1)创建Query对象,写hql语句
(2)调用query对象里面的方法得到结果
2 查询所有:from实体类名称
//1 创建query对象 Query query = session.createQuery("from Customer"); //2 调用方法得到结果 List<Customer> list = query.list();
条件查询
1 hql条件查询语句写法
(1)from 实体类名称 where 实体类名称=?and 实体类属性名称=?
from 实体类名称 where 实体类属性名称 like ?
2 代码
使用的方法是:
query.setParameter(arg0, arg1);
// 1 创建query对象 // select * from t_customer where cid=? and custName=? Query query = session.createQuery("from Customer where cid=? and custName=?"); // 2 设置条件值 // 向?里面设置值 // setParameter方法两个参数 // 第一个参数:int类型是?位置,?位置从0开始 // 第二个参数:具体参数值 // 设置第一个参数值?和preparedstatement不一样的是,它是从0开始的 query.setParameter(0, 4); // 设置第二个?值 query.setParameter(1, "baidu"); // 3 调用方法的到结果 List<Customer> list = query.list();
模糊查询
// 1 创建query对象 // select * from t_customer where cid=? and custName=? Query query = session.createQuery("from Customer where cid=? and custName like ?"); //2 设置?的值 //_na %na% query.setParameter(0, 2); query.setParameter(1, "%in%"); //3 调用方法得到结果 List<Customer> list = query.list();
hibernate底层sql代码
Hibernate: select customer0_.cid as cid1_0_, customer0_.custName as custName2_0_, customer0_.custLevel as custLeve3_0_, customer0_.custSource as custSour4_0_, customer0_.custPhone as custPhon5_0_, customer0_.custMobile as custMobi6_0_ from t_customer customer0_ where customer0_.cid=? and ( customer0_.custName like ? )
排序查询
1 hql排序语句写法
(1)from 实体类名称 order by 实体类属性名称 asc/desc
// 1 创建query对象 Query query = session.createQuery("from Customer order by cid asc"); //2 调用方法得到结果 List<Customer> list = query.list();
分页查询
1 mysql实现分页
(1)使用关键字limit实现
select * from t_customer limit 0,2;
第一个参数是开始位置,第二个参数是每页显示几条记录。
2 在hql中实现分页
(1)在hql操作中,在语句里面不能写limit(这是MySQL特有,Hibernate不认识),hibernate的Query对象封装两个方法实现分页操作。
// 1 创建query对象 Query query = session.createQuery("from Customer"); // 2 设置分页数据 // 2.1 设置开始位置 query.setFirstResult(0); // 2.2 设置每页记录数 query.setMaxResults(2); // 3 调用方法得到结果 List<Customer> list = query.list();
投影查询
1 投影查询
聚集函数使用
以上是关于hibernate学习的主要内容,如果未能解决你的问题,请参考以下文章