网站大量收购闲置独家精品文档,联系QQ:2885784924

day20-MyBatis高级查询与分页教程.doc

  1. 1、本文档共20页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
day20-MyBatis高级查询与分页教程

MyBatis高级查询与分页 一 课程介绍 高级查询 1 高级查询的概念 2 #与$的区别 3 使用代码完成高极查询 4 使用MyBatis完成高级查询 5 Web页面完成高级查询 分页功能 1 真分页与假分页 2 分页的设计原理 3 后台完成分页功能 4 前台完成分页 高级查询与分页的集成(难点) 二 高级查询 2.1 高级查询的概念 什么叫高级查询? 为什么我们需要高级查询?在我们的课程系统中,高级查询就是多条件查询。大家在上网的时候一定遇到很多这种相应 的查询功能。它可以帮我们更快更好的找到需要的信息与资源。 试想一下,以后咱们做一个客户管理系统。 一张表中有10000多个客户,我们是让用户从10000多个人中去找,还是根据一些条件(如名称,性别等)过一次过滤查询就找到。 下面为一些经常看到的高级查询: 以咱们的Product这个货品为例:如果我们现在要根据这个货品的名称与价格做高级查询应该是怎么样的呢? 下图分析: 根据上面的分析我们可以得出以下结论: 1 高级查询就是在查询基础上添加后面的where条件 2 根据不同的情况,where后面的条件都不同的 3 提供的过滤条件越多,我们查询的排列组合也就越多 综上可以看到,我们需要提供相应的查询字段,但是会不会用到,就看客户自己。但是由于这么多排列组合,我们不可能把所有的Sql全部准备好。 因此,咱们必需要能生成动态SQL(说白了就是根据用户选择条件来拼接字符串(where语句)) 怎么拼接呢?用户选择了,这个字段就不为空,当这个字段不为空的时候,我们就在where后的查询加上这个条件过滤 2.2 使用代码完成高级查询 在完成高级查询之前,我们要准备一个Query对象。 为什么要准备这个Query对象呢? 1 查询的条件是有很多的,如果我们不封装成对象,传多个参数的话很麻烦,也不利于以后的修改与扩展 2 调用MyBatis中配置的sql的时候,只能传一个参数,那咱们只有把所有参数都封装到一个对象中,然后把这个对象传递过去 Query对象就是咱们的查询对象,创建Query对象是有一定的规范的: 它应该在一个query包中,这个包与domain同级,名称为XxxQueryXxx表示实体的名称 如:StudentQuery/ProductQuery 在Query中我们准备好相应的查询条件字段与属性(Query就是一个JavaBean) 根据上面的分析,咱们为Product准备相应的Query对象: public class ProductQuery { private String name; //商品名称 private BigDecimal maxPrice; //最高价格 private BigDecimal minPrice; //最低价格 //提供相应的getter与setter方法 //提供一个方法来返回拼接的Sql语句 public String getWhereSql(){ ... } } 然后咱们在dao层准备一个高级查询的方法直接传入ProductQuery,如下: ListProduct queryAll(ProductQuery query); 我们接着完成这个queryAll的功能,包含xml中也搞定相应的代码。但是在使用的时候咱们会遇到问题,而解决的方案居然是把#号改成$。 讲到这里,我们得先来研究一下#与$的区别。再来完成其它的功能。 讲完#现$的区别后,咱们就来完成相应的代码。也就是拼接字符串的方案(课堂中完成): 第一种:使用where 1=1 (影响查询的效率) public String getWhereSql(){ String sql = where 1=1 ; if(productName!=null !.equals(productName)){ sql += and productName like %+productName+%; } if(maxSalePrice!=null){ sql += and salePrice =+maxSalePrice; } if(minSalePrice!=null){ sql += and salePrice =+minSalePrice; } return sql; } 第二种方式:用一个集合来保存,第一个用where,其它的用and 好处:解决了1=1的问题,代码稍显复杂 public String getWhereSql(){ String sql = ; ListString sqlList= new ArrayListString(); if(p

文档评论(0)

dajuhyy + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档