不多说,直接上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;
}