TestDao.java(测试类)

@Test
 public void findCollectionByConditionNoPage(){
  ApplicationContext ac = new ClassPathXmlApplicationContext("beans.xml");
  IElecTextService elecTextService = (IElecTextService) ac.getBean(IElecTextService.SERVICE_NAME);
  
  //封装查询条件
  ElecText electText = new ElecText();
  electText.setTextName("李");
  electText.setTextRemark("李");
  //在service中组织查询条件,查询结果
  List<ElecText> list = elecTextService.findCollectionByConditionNoPage(electText);
  if(list!=null && list.size()>0){
   for (ElecText text : list) {
    System.out.println(text.toString());
   }
  }
 }

ElecTextServiceImpl.java(service层实现类)

//增删改的方法:添加:@Transactional(isolation=Isolation.DEFAULT,propagation=Propagation.REQUIRED,readOnly=false)
 //查询的方法:不需要添加
 /**
  * SELECT * FROM elec_text o WHERE 1=1
  AND o.textName LIKE '%李%'
  AND o.textRemark LIKE '%李%'
  ORDER BY o.textDate DESC,o.textName ASC
  */
 public List<ElecText> findCollectionByConditionNoPage(ElecText electText) {
  //组织查询条件
  String condition = "";
  List<Object> paramsList = new ArrayList<Object>();//存放'?'对应的可变参量
  //名称
  String textName = electText.getTextName();
  if(StringUtils.isNotBlank(textName)){
   condition += " AND o.textName LIKE ?";
   paramsList.add("%"+textName+"%");
  }
  //备注
  String textRemark = electText.getTextRemark();
  if(StringUtils.isNotBlank(textRemark)){
   condition += " AND o.textRemark LIKE ?";
   paramsList.add("%"+textRemark+"%");
  }
  //将paramsList转换成数组
  Object [] params = paramsList.toArray();
  //排序
  Map<String, String> orderby = new LinkedHashMap<String, String>();
  orderby.put("o.textDate", "desc");
  orderby.put("o.textName", "asc");
  List<ElecText> list = elecTextDao.findCollectionByConditionNoPage(condition,params,orderby);
  return list;
 }

CommonDaoImpl.java(底层方法封装CommonDaoImpl类,Dao层)

//指定查询条件,查询对应的集合List(单表)
 /**
  * SELECT * FROM elec_text o WHERE 1=1
  AND o.textName LIKE '%李%'
  AND o.textRemark LIKE '%李%'
  ORDER BY o.textDate DESC,o.textName ASC
  */
 public List<T> findCollectionByConditionNoPage(String condition,
   Object[] params, Map<String, String> orderby) {
  String hql = " FROM "+entityClass.getSimpleName()+" o WHERE 1=1 ";
  //ORDER BY o.textDate DESC,o.textName ASC
  String orderbyHql = orderby(orderby);
  String finalHql = hql + condition + orderbyHql;
  //执行hql语句
  List<T> list = this.getHibernateTemplate().find(finalHql,params);
  return list;
 }
 
 //解析map集合,获取orderby的排序条件
 private String orderby(Map<String, String> orderby){
  StringBuffer buffer = new StringBuffer("");
  if(orderby!=null && orderby.size()>0){
   buffer.append(" ORDER BY ");
   for(Map.Entry<String, String> map:orderby.entrySet()){
    buffer.append(map.getKey()).append(map.getValue()).append(",");
   }
   //删除最后一个逗号
   buffer.deleteCharAt(buffer.length()-1);
  }
  return buffer.toString();
 }

Service层下orderby.put("o.textDate ", "desc");   不加空格会报错

错误提示如下:

Caused by: org.hibernate.QueryException: could not resolve property: textDatedesc of: cn.itcast.elec.domain.ElecText [ FROM cn.itcast.elec.domain.ElecText o WHERE 1=1  AND o.textName LIKE ? AND o.textRemark LIKE ? ORDER BY o.textDatedesc,o.textNameasc]

出现错误的代码如下:

//排序
  Map<String, String> orderby = new LinkedHashMap<String, String>();
  orderby.put("o.textDate", "desc");
  orderby.put("o.textName", "asc");
  List<ElecText> list = elecTextDao.findCollectionByConditionNoPage(condition,params,orderby);
  return list;

指定查询条件,查询对应的集合List(单表)的更多相关文章

  1. EF:分页查询 + 条件查询 + 排序

    /// <summary> /// linq扩展类---zxh /// </summary> /// <typeparam name="T">& ...

  2. springdata 查询思路:基本的单表查询方法(id,sort) ---->较复杂的单表查询(注解方式,原生sql)--->实现继承类---->复杂的多表联合查询 onetomany

    springdata 查询思路:基本的单表查询方法(id,sort) ---->较复杂的单表查询(注解方式,原生sql)--->实现继承类---->复杂的多表联合查询 onetoma ...

  3. Hibernate 笔记 HQL查询 条件查询,聚集函数,子查询,导航查询

    在hibernate中进行多表查询,每个表中各取几个字段,也就是说查询出来的结果集并没有一个实体类与之对应,如何解决这个问题? 解决方案一,按照Object[]数据取出数据,然后自己组bean 解决方 ...

  4. MySQL单表查询 条件查询,分组

    目录 1 where 条件查询 between like not in 2 group by 分组 聚合函数:max min sum avg count 3 having 过滤 4 distinct ...

  5. 18 12 06 sql 的 基本语句 查询 条件查询 逻辑运算符 模糊查询 范围查询 排序 聚合函数 分组 分页 连接查询 自关联 子查询

    -- 数据的准备 -- 创建一个数据库 create database python_test charset=utf8; -- 使用一个数据库 use python_test; -- 显示使用的当前 ...

  6. Activiti5 待审 待批任务 TaskQuery查询 条件查询 like查询

    TaskQuery查询API 有两种方法可以从引擎中查询数据:查询API和原生查询.查询API提供了完全类型安全的API. 你可以为自己的查询条件添加很多条件 (所以条件都以AND组合)和精确的排序条 ...

  7. 13-MySQL-Ubuntu-数据表的查询-条件查询(二)

    条件查询 1,比较查询(>,<,>=,<=,=)注:SQL查询语句的等于号(=) (1)查询学生表中年龄大于18岁的学生姓名和性别信息 select name,gender f ...

  8. 五 查询数据SELECT   一、单表查询

    一 单表查询的语法 二 关键字的执行优先级 三 简单查询 四 WHERE约束 五 分组查询:GROUP BY 六 HAVING过滤 七 查询排序:ORDER BY 八 限制查询的记录数:LIMIT 九 ...

  9. 在PLSQL中不能使用中文作为查询条件查询数据

    解决方法:  1.在oracle服务端的注册表中找到oracle-->key_oradb11g_home1,在右侧找到NLS_LANG,将其数值数据改为SIMPLIFIED CHINESE_CH ...

  10. [NHibernate]条件查询Criteria Query

    目录 写在前面 文档与系列文章 条件查询 一个例子 总结 写在前面 上篇文章介绍了HQL查询,我个人觉得使用ORM框架就是为了让少些sql,提高开发效率,而再使用HQL就好像还是使用sql,就觉得有点 ...

随机推荐

  1. macOS(Sierra 10.12)上Android源码(AOSP)的下载、编译与导入到Android Studio

    @import url(http://i.cnblogs.com/Load.ashx?type=style&file=SyntaxHighlighter.css);@import url(/c ...

  2. js-点击按钮页面滚动到顶部,底部,指定位置

    之所以笔记一下这个,因为我在项目中经常用到. $('.scroll_top').click(function(){$('html,body').animate({scrollTop: '0px'}, ...

  3. luogu P2158 [SDOI2008]仪仗队

    题目描述 作为体育委员,C君负责这次运动会仪仗队的训练.仪仗队是由学生组成的N * N的方阵,为了保证队伍在行进中整齐划一,C君会跟在仪仗队的左后方,根据其视线所及的学生人数来判断队伍是否整齐(如下图 ...

  4. 这道js面试题号称99%的人会做错

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  5. cacti监控linux和windows磁盘IO

    cacti监控linux和windows磁盘IO 标签:cacti linux磁盘IO windows磁盘IO 原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则 ...

  6. iOS -- 设置label的自适应

    - (void)AutoLabel { //准备工作 self.font = [UIFont systemFontOfSize:]; self.textColor = [UIColor whiteCo ...

  7. win7 32位配置apache+wsgi+django环境

    1下载xampp,里面有apache,mysql,phpmyadmin, 2 下载wsgi,http://download.csdn.net/download/copter/9192361 将对应的模 ...

  8. android wifi state and wifi ap state

    /** * Wi-Fi is currently being disabled. The state will change to {@link #WIFI_STATE_DISABLED} if * ...

  9. log4net菜鸟指南二----生成access和txt

    前言 有可能目标计算机缺少某些组件,导致无法生成access文件,或者打不开文件,这时txt文件就可以方便的使用了 一,标准的控制台程序输出日志到access <?xml version=&qu ...

  10. jquery获取<div></div>之间的内容.text() 和 .html()区别

    jQuery 获取 div 之间的内容,有两种方法,$(selector).text().$(selector).html() . html: <div> <p>test< ...