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

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

	public List getUser(User user){
		List 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;
	}


 

你可能感兴趣的:(Hibernate模糊查询之多条件任意组合查询)