- 1、本文档共20页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 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
您可能关注的文档
- C语言程序设计基础复习教程.ppt
- led灯珠参数与应用.ppt
- C语言程序设计第2章数据类型、运算符和表达式教程.ppt
- C语言程序设计第四版PPT_谭浩强5章教程.ppt
- lanse简介模板.pptx
- c语言程序课程设计报告电费系统教程.docx
- C语言程序设计李泽中课件第4章教程.ppt
- C语言第03章教程.ppt
- C语言程序设计第四版PPT_谭浩强2章教程.ppt
- c语言笔试题教程.doc
- 2024年学校党总支巡察整改专题民主生活会个人对照检查材料3.docx
- 2025年民主生活会个人对照检查发言材料(四个带头).docx
- 县委常委班子2025年专题生活会带头严守政治纪律和政治规矩,维护党的团结统一等“四个带头方面”对照检查材料四个带头:.docx
- 巡察整改专题民主生活会个人对照检查材料5.docx
- 2024年度围绕带头增强党性、严守纪律、砥砺作风方面等“四个方面”自我对照(问题、措施)7.docx
- 2025年度民主生活会领导班子对照检查材料(“四个带头”).docx
- 国企党委书记2025年度民主生活会个人对照检查材料(五个带头).docx
- 带头严守政治纪律和政治规矩,维护党的团结统一等(四个方面)存在的问题整改发言提纲.docx
- 党委书记党组书记2025年带头增强党性、严守纪律、砥砺作风方面等“四个带头”个人对照检查发言材料.docx
- 2025年巡视巡察专题民主生活会对照检查材料.docx
最近下载
- 重庆市两江新区2024-2025学年数学六年级第一学期期末检测试题含解析.doc VIP
- 人教版(2024年新版)七年级上册美术全册教学设计.docx
- Desouttter马头电动装配系统CVI3 系列 CVI3 Controllers CVI3 Vision (6159326910) CVI3 tightening controllers Conf.pdf
- 【MOOC】时间序列分析-中南财经政法大学 中国大学慕课MOOC答案.docx
- 2024-2025学年重庆市六年级数学第一学期期末检测试题含解析.doc VIP
- 高中政治(必修1+必修2)期末测试卷(二)(原卷版).docx VIP
- 高中生物 2023-2024学年安徽省合肥高一(上)期末生物试卷.pdf
- 太阳能光伏产业链垂直一体化构建研究.docx VIP
- SSCI收录管理学种期刊目录.docx
- GB51016-2014 非煤露天矿边坡工程技术规范.pdf
文档评论(0)