动态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)
上一篇 2022年5月9日 下午11:20
下一篇 2022年5月9日 下午11:40


相关推荐

  • Matlab赋值_matlab二维数组赋值

    Matlab赋值_matlab二维数组赋值clear;clc;x=[23457810111415161819];y=[106。42108。26109。58109。5110109。93110。49110。59110。6110。9110。76111111。2];x3=min(x):0。1:max(x);%可以放在循环外%v=zeros(3,6);没有必要,需要的话可以,v=[];forn=1:…

    2026年4月15日
    4
  • 【软件工程】敏捷宣言

    【软件工程】敏捷宣言转载 敏捷宣言以及敏捷开发的特点 鸿鹄当高远 博客园敏捷宣言敏捷宣言 也叫做敏捷软件开发宣言 正式宣布了对四种核心价值和十二条原则 可以指导迭代的以人为中心的软件开发方法 nbsp 敏捷宣言强调的敏捷软件开发的四个核心价值是 个体和互动高于流程和工具工作的软件高于详尽的文档客户合作高于合同谈判响应变化高于遵循计划敏捷开发的第一条价值观就是 以人为本 强调 个体 人 及 个体

    2026年3月19日
    4
  • vlan的基础配置_图文并茂的图片制作二年级

    vlan的基础配置_图文并茂的图片制作二年级VLAN的简单配置实例(图文并茂)一.实验环境首先我们得有简单的实验环境:GNS3,C2691路由器二.实验图示如图,先建立如图所示的简单拓扑图。注:记得给交换机设置好参数。如图三.实验步骤首先我们得配置好三台主机的ip地址。配置如图。pc1pc2pc3主机配置完成。接下来我们开始设置交换机。如图我们可以查看路由功能查看我们已经设置好的vlan和接口。先配好三个vlan…

    2026年1月26日
    9
  • Feign使用Hystrix

    Feign使用HystrixFeigh是以接口形式工作,它没有方法体,那么Feign如何整合Hystrix呢?如何实现Feign的回退呢?事实上,Spring Cloud默认已经为Feign整合了Hystrix,下面看一个实例。一 新建项目microservice-consumer-movie-feign-hystrix-fallback二 编写Feigh接口packagecom.itmuch.cloud.study.us…

    2025年6月1日
    5
  • 基于Krack的网络攻击「建议收藏」

    基于Krack的网络攻击「建议收藏」更新软件包apt-getupdate安装相应的环境apt-getinstalllibnl-3-devlibnl-genl-3-devpkg-configlibssl-devnet-toolsgitsysfsutilspython-scapypython-pycryptodome下载Krack运行脚本gitclonehttps://github.com/…

    2022年6月10日
    39
  • Oracle ORA-01017 报错处理

    Oracle ORA-01017 报错处理Oracle ORA-01017报错处理背景: 通过toad连接Oracle11gRAC数据库是,发现通过sys用户连接总是报ORA-01017错误,tnsping连接名称是通的,其他用户连接是正常的,反复输入sys账户信息,总提示:1.尝试改sys用户密码,重试报错依旧。 2.使用sys登录GC,报错相同。使用普通用户登录正常。 3.数据库服务器上使用sqlplus

    2022年5月31日
    710

发表回复

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

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