动态sql模糊查询和分页「建议收藏」

动态sql模糊查询和分页「建议收藏」文章目录动态sql模糊查询查询返回结果集的处理分页动态sqlBookMapperxmlbookservice测试:MapperSql.test运行:模糊查询BookMapperBookMapper.xmlBookserviceStringUtiles测试:一共介绍了三种模糊查询的方法,对比第三种更加实用。运行:查询返回结果集的处理BookM…

大家好,又见面了,我是你们的朋友全栈君。

动态sql

BookMapper
在这里插入图片描述
xml
在这里插入图片描述
bookservice
在这里插入图片描述
测试:
MapperSql.test
在这里插入图片描述
运行:
在这里插入图片描述

模糊查询

BookMapper
在这里插入图片描述
BookMapper.xml
在这里插入图片描述
Bookservice
在这里插入图片描述
StringUtiles
在这里插入图片描述
测试:
一共介绍了三种模糊查询的方法,
对比第三种更加实用。
在这里插入图片描述
运行:
在这里插入图片描述

查询返回结果集的处理

BookMapper
在这里插入图片描述
Bookmapper.xml

 <select id="List1" resultMap="BaseResultMap">
    select * from t_mvc_book
  </select>
  <select id="List2" resultType="com.caoluo.model.Book">
    select * from t_mvc_book
  </select>
  <select id="list3" resultType="com.caoluo.model.Book" parameterType="com.caoluo.model.BookVo">
    select * from t_mvc_book where bid in
    <foreach collection="bookIds" open="(" close=")" separator="," item="bid">
    #{bid}
    </foreach>
  </select>
  <select id="list4" resultType="java.util.Map" parameterType="java.util.Map" >
      select * from t_mvc_book
      <where>
        <if test="null != bname and bname !=''">
          and bname like #{bname}
        </if>
      </where>
  </select>
  <select id="list5" resultType="java.util.Map" parameterType="java.util.Map">
    select * from t_mvc_book
    <where>
      <if test="null != bid and bid !=''">
        and bid = #{bid}
      </if>
    </where>
  </select>
</mapper>

BookVo继承Book实体类
在这里插入图片描述
测试代码

 @Test
    public void list() {
        //返回resultMap但是使用list<T>
//        List<Book> books=this.bookService.List1();
        //返回的是resulttype使用list<T>接收
//        List<Book> books=this.bookService.List2();
//        for (Book b :books){
//            System.out.print(b);
//        }
        //返回的是resulttype 使用T接收
//        BookVo bookVo=new BookVo();
//        List list=new ArrayList();
//        list.add(5);
//        bookVo.setBookIds(list);
//        Book book=this.bookService.list3(bookVo);
//        System.out.print(book);
        //返回的是resultType,然后用list<map>进行接收
        Map map=new HashMap();
//        map.put("bname",StringUtils.toLikeStr("李四"));
//        List<Map> list=this.bookService.list4(map);
//        for (Map m :list){
//            System.out.print(m);
//        }
//        /返回的是resultType,然后用map进行接收
        map.put("bid",7);
        Map m=this.bookService.list5(map);
        System.out.print(m);

分页

为什么要重写mybatis的分页?
Mybatis的分页功能很弱,它是基于内存的分页(查出所有记录再按偏移量offset和边界limit取结果),在大数据量的情况下这样的分页基本上是没有用的

使用分页插件步奏
1、导入pom依赖
2、Mybatis.cfg.xml配置拦截器
3、使用PageHelper进行分页
4、处理分页结果
Pom依赖

<dependency>
    <groupId>com.github.pagehelper</groupId>
    <artifactId>pagehelper</artifactId>
    <version>5.1.2</version>
</dependency>

Mybatis.cfg.xml配置拦截器

<plugins>
    <!-- 配置分页插件PageHelper, 4.0.0以后的版本支持自动识别使用的数据库 -->
    <plugin interceptor="com.github.pagehelper.PageInterceptor">
    </plugin>
</plugins>

Bookservice层

在这里插入图片描述
BookServiceImpl
在这里插入图片描述
测试:
在这里插入图片描述
运行:
在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/142086.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 配置缺省路由_缺省路由下一跳

    配置缺省路由_缺省路由下一跳缺省路由(默认路由),易目的网络为0.0.0.0,子网掩码为0.0.0.0的形式出现。应用缺省路由可减少路由表的规模,减少维护压力。如下图对于交换机A而言,要去往交换机B所直连的PC1\PC2,就需要有路由的指引。如果我们配置静态路由的话,就需要在交换机A上配置两条静态路由。即增加了配置工作量,又增加了交换机A的负担。因为交换机需要维护更多的路由条目,而承载路由条目的路由表需要占用设备内存资源。为优化网络设计,在保证路由可达的情况下,可以尽量减少路由表的路由条目。在下图场景下,我们可以配置一条缺省路由

    2025年7月13日
    0
  • oauth 流程_简明同义词典

    oauth 流程_简明同义词典SSO:用户一次登陆后在多个系统免登录。博客gem'doorkeeper'https://i.cnblogs.com/EditPosts.aspx?postid=9255973

    2022年8月2日
    5
  • mysql创建新用户并分配权限

    mysql创建新用户并分配权限

    2022年3月12日
    42
  • reduce实现数组求和_js数组reduce

    reduce实现数组求和_js数组reducereducereduce收敛4个参数,返回的是叠加后的结果,原数组不发生变化,回调函数返回的结果//从左向右//prev代表前一项,cur代表当前项【求和】letarr=[1,3,5,8,9,7];letsum=arr.reduce(function(prev,cur,index,arr){ //return100;//本次的返回值…

    2022年9月27日
    0
  • MATLAB(R2021a)软件下载和安装教程[通俗易懂]

    MATLAB(R2021a)软件下载和安装教程[通俗易懂][名称]:MatlabR2021a[大小]:17.11GB[语言]:简体中文[安装环境]:Win7/Win8/Win10[64位下载链接]:https://pan.baidu.com/s/1jnp9OeXZRnwScGU68K03CQ[提取码]:1234[阿里云下载地址]:(推荐使用)https://www.aliyundrive.com/s/BYPHMoAiLqq[备用链接]:若下载链接失效,获取最新下载链接请到公众号『软件科技汇』后台回复:matlab软件..

    2022年7月26日
    17
  • 构建LAMP架构_lamp和lnmp区别

    构建LAMP架构_lamp和lnmp区别LAMP架构LAMP架构简介Apache简介编译安装Apache编译安装Mysql编译安装PHP编译安装phpMyadminLAMP架构简介LAMP架构是目前成熟的企业网站应用模式之一,指的是协同工作的一整套系统和相关软件,能够提供动态Web站点服务及其应用开发环境。LAMP是一个缩写词,具体包括Linux操作系统、Apache网站服务器、MySQL数据库服务器、PHP(或Perl、Python)网页编程语言。Apache简介ApacheHTTPServer是开源软件项目的杰出

    2022年10月9日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号