Hibernate模糊查询之多条件任意组合查询

不多说,直接上dao层该查询方法代码,一共是三种(HQL,QBC,QBE):

	public List<User> getUser(User user){
		List<User> list = null;
		String hql = null;
		try {
			String name = user.getUname();
			String sex = user.getUsex();
			String phone = user.getUphone();
			String addr = user.getUaddr();
			String lv = user.getUlv();

			session = HibernateSessionFactory.getSession();
			tran = session.beginTransaction();

			/********************* 普通方式(HQL) *************************/
			// hql = "from User where 1=1";
			// if(name != null && !"".equals(name)){
			// hql = hql+" and uname like '%"+name+"%'";
			// }
			// if(sex != null && !"".equals(sex)){
			// hql = hql+" and usex like '%"+sex+"%'";
			// }
			// if(phone != null && !"".equals(phone)){
			// hql = hql+" and uphone like '%"+phone+"%'";
			// }
			// if(lv != null && !"".equals(lv)){
			// hql = hql+" and ulv like '%"+lv+"%'";
			// }
			// if(addr != null && !"".equals(addr)){
			// hql = hql+" and uaddr like '%"+addr+"%'";
			// }
			// Query query = session.createQuery(hql);
			// list = query.list();

			/********************* QBC查询方式 ***********************/
			// Criteria c = session.createCriteria(User.class);
			// if(name != null && !"".equals(name)){
			// c.add(Restrictions.like("uname", name,MatchMode.ANYWHERE));
			// }
			// if(sex != null && !"".equals(sex)){
			// c.add(Restrictions.like("usex", sex,MatchMode.ANYWHERE));
			// }
			// if(phone != null && !"".equals(phone)){
			// c.add(Restrictions.like("uphone", phone,MatchMode.ANYWHERE));
			// }
			// if(lv != null && !"".equals(lv)){
			// c.add(Restrictions.like("ulv", lv,MatchMode.ANYWHERE));
			// }
			// if(addr != null && !"".equals(addr)){
			// c.add(Restrictions.like("uaddr", addr,MatchMode.ANYWHERE));
			// }
			// list = c.list();

			/********************** QBE查询方式 *********************/
			// User u = new User();
			// if (name != null && !"".equals(name)) {
			// u.setUname("%" + name + "%");
			// }
			// if (sex != null && !"".equals(sex)) {
			// u.setUsex("%" + sex + "%");
			// }
			// if (phone != null && !"".equals(phone)) {
			// u.setUphone("%" + phone + "%");
			// }
			// if (lv != null && !"".equals(lv)) {
			// u.setUlv("%" + lv + "%");
			// }
			// if (addr != null && !"".equals(addr)) {
			// u.setUaddr("%" + addr + "%");
			// }
			// Example e = Example.create(u).enableLike();
			// Criteria c = session.createCriteria(User.class).add(e);
			// list = c.list();
			
			tran.commit();
		} catch (HibernateException e) {
			tran.rollback();
			e.printStackTrace();
		}
		return list;
	}


 

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值