Hibernate模糊查询三种方式

1、如果是Query query = session.createQuery("")的话,试一下去掉前面的“select *”即createQuery方法内的条件直接是“from ......”,有几个是可以用的,因为支持部分SQL。

不行的话就用下面的格式(排序必用):   

select OBJECT(o) from A o where o.b in(21,32)
select OBJECT(o) from A o order by o.b ASC 

2、Hibernate中实现模糊查询,可有以下三种方式:

第一种方式:QBC查询

String name = "", info = "";
if (sub != null && sub.getSubname() != null) {
  name = sub.getSubname();
}
if (sub != null && sub.getSubinfo() != null) {
  info = sub.getSubinfo();
}
Criteria cr = session.createCriteria(Subject.class);
cr.add(Expression.like("subname","%"+name+"%"));
cr.add(Expression.like("subinfo","%"+info+"%")); 

第二种方式:HQL查询语句

String hql = "from Subject as s where s.subname like :name and s.subinfo like :info";
// 调用session的获得数据列表方法,传递HQL查询语句
   Query query = session.createQuery(hql);
   query.setString("name","%"+name+"%");
   query.setString("info","%"+info+"%");
   System.out.println("*********"+hql); 


第三种方式:HQL查询语句(查询条件只能为英文或数字,汉字在传递到hibernate内部时出现乱码问题

String hql = "from Subject as s where s.subname like '%"+name+"%' and s.subinfo like '%"+info+"%'";
//调用session的获得数据列表方法,传递HQL查询语句
Query query = session.createQuery(hql); 

注:Subject为数据库表subject映射的类;它有相应的属性subname、subinfo及相应的get和set方法;sub为Subject的一个实例化对象。




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值