mybatis的动态查询

这里是修真院后端小课堂,每篇分享文从

【背景介绍】【知识剖析】【常见问题】【解决方案】【编码实战】【扩展思考】【更多讨论】【参考文献】

八个方面深度解析后端知识/技能,本篇分享的是:

【mybatis的动态查询】

大家好,我是IT修真院深圳分院第10期的JAVA学员,一枚正直纯洁善良的java程序员。

今天给大家分享一下,修真院官网Java任务5,深度思考中的知识点—mybatis的动态查询

1.背景介绍

MyBatis是支持普通SQL查询,存储过程和高级映射的优秀持久层框架。MyBatis消除了几乎所有的JDBC代码如参数的手工设置以及结果集的检索。MyBatis 使用简单的 XML或注解用于配置和原始映射,将接口和JavaBean映射成数据库中的记录。

每个MyBatis应用程序主要都是使用SqlSessionFactory实例的,一个SqlSessionFactory实例可以通过SqlSessionFactoryBuilder获得。SqlSessionFactoryBuilder可以从一个xml配置文件或者一个预定义的配置类的实例获得。

Mybatis的特点:

简单易学:本身就很小且简单。没有任何第三方依赖,最简单的安装只要两个jar文件+配置几个sql映射文件。

灵活:mybatis不会对应用程序或者数据库的现有设计强加任何影响。 sql写在xml里,便于统一管理和优化。

解除sql与程序代码的耦合:通过提供DAL层,将业务逻辑和数据访问逻辑分离,使系统的设计更清晰,更易维护,更易单元测试。sql和代码的分离,提高了可维护性。

半自动映射框架:其被称为半自动是因为需要手工配置POJO,sql和映射关系,所有的功能通过编写SQL来实现。

提供了对底层JDBC数据访问的封装

提供强大的数据映射功能(传入参数映射和结果数据映射)

Mybtais运行的总体流程

(1)加载配置并初始化

触发条件:加载配置文件

处理过程:将SQL的配置信息加载成为一个个MappedStatement对象(包括了传入参数映射配置、执行的SQL语句、结果映射配置),存储在内存中。

这里说下,一个MappedStatement对象对应Mapper配置文件中的一个select/update/insert/delete节点,主要描述的是一条SQL语句。

(2)接收调用请求

触发条件:调用Mybatis提供的API

传入参数:SQL的ID和传入参数对象

处理过程:将请求传递给下层的请求处理层进行处理。

(3)处理操作请求

触发条件:API接口层传递请求过来

传入参数:SQL的ID和传入参数对象

处理过程:

(A)根据SQL的ID查找对应的MappedStatement对象。

(B)根据传入参数对象解析MappedStatement对象,得到最终要执行的SQL和执行传入参数。

(C)获取数据库连接,根据得到的最终SQL语句和执行传入参数到数据库执行,并得到执行结果。

(D)根据MappedStatement对象中的结果映射配置对得到的执行结果进行转换处理,并得到最终的处理结果。

(E)释放连接资源。

(4)返回处理结果:

将操作数据库的结果按照映射的配置进行转换,可以转换成HashMap、JavaBean或者基本数据类型,并将最终结果返回。

2.知识剖析

1.mybatis配置文件

2.动态SQL语句

配置文件标签

1、Properties属性:用来加载属性配置文件。

Mybatis将按照下面的顺序来加载属性:

   (1) 首先会读取在property标签中定义的属性。

   (2) 然后会读取在properties标签中通过resource或url加载时的属性,它会覆盖已读取得同名属性。

   (3) 最后会读取sql中parameterType传递过来的属性,它会覆盖已读取的同名属性。

因此,通过方法参数传递的属性具有最高优先级,resource/url 属性中指定的配置文件次之,最低优先级的是 properties 属性中指定的属性。

2、settings全局参数配置:Mybatis框架在运行时可以调整一些运行参数,比如:开启二级缓存、开启延迟加载等。

3、typeAliases类型别名:类型别名是为 Java 类型设置一个短的名字。它只和 XML 配置有关,存在的意义仅在于用来减少类完全限定名的冗余。

4、配置环境(environments):MyBatis 可以配置成适应多种环境,这种机制有助于将 SQL 映射应用于多种数据库之中,例如,开发、测试和生产环境需要有不同的配置;

不过:尽管可以配置多个环境,每个 SqlSessionFactory 实例只能选择其一。所以,如果我们想连接两个数据库,就需要创建两个 SqlSessionFactory 实例,每个数据库对应一个。

为了指定创建哪种环境,只要将它作为可选的参数传递给 SqlSessionFactoryBuilder 即可。可以接受环境配置的两个方法签名是:

SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(reader,environment);

SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(reader,environment,properties);

如果忽略了环境参数,那么默认环境将会被加载。

5、事务管理器(transactionManager)

在 MyBatis 中有两种类型的事务管理器(也就是 type=”[JDBC|MANAGED]”):

JDBC – 这个配置就是直接使用了 JDBC 的提交和回滚设置,它依赖于从数据源得到的连接来管理事务作用域。

MANAGED – 这个配置几乎没做什么。它从来不提交或回滚一个连接,而是让容器来管理事务的整个生命周期(比如 JEE 应用服务器的上下文)。 默认情况下它会关闭连接,然而一些容器并不希望这样,因此需要将 closeConnection 属性设置为 false 来阻止它默认的关闭行为。

6、typeHandlers类型处理器

无论是 MyBatis 在预处理语句(PreparedStatement)中设置一个参数时,还是从结果集中取出一个值时, 都会用类型处理器将获取的值以合适的方式转换成 Java 类型。即专门用来解决数据库中的数据类型和Java中的数据类型之间的转化问题。

mybatis有一系列的默认的类型处理器,所以在平时开发的时候我们不用去关心java到数据库的类型转化关系,mybatis都帮我们把这些工作完成了。当然我们也可以重写类型处理器或创建你自己的类型处理器来处理不支持的或非标准的类型。

动态SQL语句

       MyBatis 的强大特性之一便是它的动态 SQL。mybatis 的动态sql语句是基于OGNL表达式的。可以方便的在 sql 语句中实现某些逻辑. 总体说来mybatis 动态SQL 语句主要有以下几类:

1. if 语句 (简单的条件判断)

2. choose (when,otherwize),相当于java 语言中的 switch 

3. trim :

(1)只有prefix,suffix 表示在trim标签包裹的部分的前面或者后面添加内容

(2)只有prefixOverrides,suffixOverrides 表示删除

4. where (主要是用来简化sql语句中where条件判断的,能智能的处理 and /or,不必担心多余导致语法错误)

5. set (主要用于更新时):

1)、程序执行时,将生成set关键字

2)、会过滤掉最后一个update语句的","

6. foreach (在实现 mybatis in 语句查询时特别有用)

1)、collection表示如何来得到这个集合,如果传入的直接为一个List,那么collection值就为list。

  2)、item表示集合中每一个元素进行迭代时的别名,比如item为value,那么,每次获取的都使用#{value}即可

  3)、index指定一个名字,用于表示在迭代过程中,每次迭代到的位置

  4)、open表示该语句以什么开始

  5)、separator表示在每次进行迭代之间以什么符号作为分隔符

  6)、close表示以什么结束

3.常见问题

如何配置mybatis的逆向工程,生成代码?

4.解决方案

1)新建一个和原工程文件名字相同的项目,创建一个xml配置文件:


       
       <context id="testTables" targetRuntime="MyBatis3">
           
               
               
           

           
           <jdbcConnection driverClass="com.mysql.jdbc.Driver"
                           connectionURL="jdbc:mysql:///more_pineapple" userId="root"
                           password="root123">
           
           
           
               
           

           
           <javaModelGenerator targetPackage="src.main.java.com.jnshu.backendsystem.pojo"
                               targetProject=".\src">
               
               
               
               
           
           
           <sqlMapGenerator targetPackage="src.main..resources.mappers"
                            targetProject=".\src">
               
               
           
           
           <javaClientGenerator type="XMLMAPPER"
                                targetPackage="src.main.java.com.jnshu.backendsystem.dao"
                                targetProject=".\src">
               
               
           
           
           <table schema="" tableName="banner_show"></table>
           <table schema="" tableName="company_info"></table>
           <table schema="" tableName="company_produce"></table>
           <table schema="" tableName="position_info"></table>
           <table schema="" tableName="module_table"></table>
       
   

在配置文件中,配置生成工程文件的路径、数据库用户名、密码、表字段等。

然后新建一个执行类

com.jnshu.mybatisorg.mybatis.generator.api.MyBatisGeneratororg.mybatis.generator.config.Configurationorg.mybatis.generator.config.xml.ConfigurationParserorg.mybatis.generator.internal.DefaultShellCallbackjava.io.Filejava.util.ArrayListjava.util.ListGeneratorSqlmap {
    () Exception{

        List warnings = ArrayList()overwrite = File configFile = File()ConfigurationParser cp = ConfigurationParser(warnings)Configuration config = cp.parseConfiguration(configFile)DefaultShellCallback callback = DefaultShellCallback(overwrite)MyBatisGenerator myBatisGenerator = MyBatisGenerator(configcallbackwarnings)myBatisGenerator.generate()}
    (String[] args) Exception {
        {
            GeneratorSqlmap generatorSqlmap = GeneratorSqlmap()generatorSqlmap.generator()} (Exception e) {
            e.printStackTrace()}

    }

}

然后执行程序就可以了,就会生出相对应的实体层、dao层和映射层。

5.编码实战

6.扩展思考

7.参考文献

链接:https://baike.baidu.com/item/MyBatis/2824918?fr=aladdin

作者:百度百科

链接:https://www.jb51.cc/

作者:w3cschool

链接:http://www.mybatis.org/mybatis-3/zh/configuration.html#typeHandlers

作者:Mybatis

链接: https://blog.csdn.net/happyheng/article/details/70232136

8.更多讨论

1)mybatis动态查询的好处有哪些?

mybatis的动态查询,可以根据输入参数,选择相对应的条件,对结果进行筛选,这个过程是动态的,可以变化的,并不是固定不变的。

2)在真实开发的过程当中,如何处理多选参数?数据库mapper文件该如何设置?

select
    c.company_id,c.company_name,c.company_logo,c.city,c.area,c.company_industry,c.financing_scale,(p.position_id)
    as numberOfPositions
    from company_info c,position_info p
    c.company_id=p.company_id AND p.is_online = 1
        AND c.company_name LIKE CONCAT('%',#{companyName},'%')
        AND c.city IN
            #{city}
            AND c.company_industry IN
            #{companyIndustry}
            AND c.financing_scale IN
            #{financingScale}
            GROUP BY c.company_id

3)如何遍历传过来的数组?

可以使用foreach标签遍历

AND c.financing_scale IN
    #{financingScale}

  

今天的分享就到这里啦,欢迎大家点赞、转发、留言、拍砖~

技能树.IT修真院“我们相信人人都可以成为一个工程师,现在开始,找个师兄,带你入门,掌控自己学习的节奏,学习的路上不再迷茫”。

这里是技能树.IT修真院,成千上万的师兄在这里找到了自己的学习路线,学习透明化,成长可见化,师兄1对1免费指导。快来与我一起学习吧~我的邀请码:23656198,或者你可以直接点击此链接:http://www.jnshu.com/login/1/23656198

PPT链接 视频链接

更多内容,可以加入IT交流群565734203与大家一起讨论交流

这里是技能树·IT修真院:,初学者转行到互联网的聚集地

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

相关推荐


摘要: 原创出处 https://www.bysocket.com 「公众号:泥瓦匠BYSocket 」欢迎关注和转载,保留摘要,谢谢! 目录 连接 连接池产生原因 连接池实现原理 小结 TEMPERANCE:Eat not to dullness;drink not to elevation.节制
摘要: 原创出处 https://www.bysocket.com 「公众号:泥瓦匠BYSocket 」欢迎关注和转载,保留摘要,谢谢! 一个优秀的工程师和一个普通的工程师的区别,不是满天飞的架构图,他的功底体现在所写的每一行代码上。-- 毕玄 1. 命名风格 【书摘】类名用 UpperCamelC
今天犯了个错:“接口变动,伤筋动骨,除非你确定只有你一个人在用”。哪怕只是throw了一个新的Exception。哈哈,这是我犯的错误。一、接口和抽象类类,即一个对象。先抽象类,就是抽象出类的基础部分,即抽象基类(抽象类)。官方定义让人费解,但是记忆方法是也不错的 —包含抽象方法的类叫做抽象类。接口
Writer :BYSocket(泥沙砖瓦浆木匠)微 博:BYSocket豆 瓣:BYSocketFaceBook:BYSocketTwitter :BYSocket一、引子文件,作为常见的数据源。关于操作文件的字节流就是 —FileInputStream&amp;FileOutputStream。
作者:泥沙砖瓦浆木匠网站:http://blog.csdn.net/jeffli1993个人签名:打算起手不凡写出鸿篇巨作的人,往往坚持不了完成第一章节。交流QQ群:【编程之美 365234583】http://qm.qq.com/cgi-bin/qm/qr?k=FhFAoaWwjP29_Aonqz
本文目录 线程与多线程 线程的运行与创建 线程的状态 1 线程与多线程 线程是什么? 线程(Thread)是一个对象(Object)。用来干什么?Java 线程(也称 JVM 线程)是 Java 进程内允许多个同时进行的任务。该进程内并发的任务成为线程(Thread),一个进程里至少一个线程。 Ja
Writer :BYSocket(泥沙砖瓦浆木匠)微 博:BYSocket豆 瓣:BYSocketFaceBook:BYSocketTwitter :BYSocket在面向对象编程中,编程人员应该在意“资源”。比如?1String hello = &quot;hello&quot;; 在代码中,我们
摘要: 原创出处 https://www.bysocket.com 「公众号:泥瓦匠BYSocket 」欢迎关注和转载,保留摘要,谢谢! 这是泥瓦匠的第103篇原创 《程序兵法:Java String 源码的排序算法(一)》 文章工程:* JDK 1.8* 工程名:algorithm-core-le
摘要: 原创出处 https://www.bysocket.com 「公众号:泥瓦匠BYSocket 」欢迎关注和转载,保留摘要,谢谢! 目录 一、父子类变量名相同会咋样? 有个小故事,今天群里面有个人问下面如图输出什么? 我回答:60。但这是错的,答案结果是 40 。我知错能改,然后说了下父子类变
作者:泥瓦匠 出处:https://www.bysocket.com/2021-10-26/mac-create-files-from-the-root-directory.html Mac 操作系统挺适合开发者进行写代码,最近碰到了一个问题,问题是如何在 macOS 根目录创建文件夹。不同的 ma
作者:李强强上一篇,泥瓦匠基础地讲了下Java I/O : Bit Operation 位运算。这一讲,泥瓦匠带你走进Java中的进制详解。一、引子在Java世界里,99%的工作都是处理这高层。那么二进制,字节码这些会在哪里用到呢?自问自答:在跨平台的时候,就凸显神功了。比如说文件读写,数据通信,还
1 线程中断 1.1 什么是线程中断? 线程中断是线程的标志位属性。而不是真正终止线程,和线程的状态无关。线程中断过程表示一个运行中的线程,通过其他线程调用了该线程的 方法,使得该线程中断标志位属性改变。 深入思考下,线程中断不是去中断了线程,恰恰是用来通知该线程应该被中断了。具体是一个标志位属性,
Writer:BYSocket(泥沙砖瓦浆木匠)微博:BYSocket豆瓣:BYSocketReprint it anywhere u want需求 项目在设计表的时候,要处理并发多的一些数据,类似订单号不能重复,要保持唯一。原本以为来个时间戳,精确到毫秒应该不错了。后来觉得是错了,测试环境下很多一
纯技术交流群 每日推荐 - 技术干货推送 跟着泥瓦匠,一起问答交流 扫一扫,我邀请你入群 纯技术交流群 每日推荐 - 技术干货推送 跟着泥瓦匠,一起问答交流 扫一扫,我邀请你入群 加微信:bysocket01
Writer:BYSocket(泥沙砖瓦浆木匠)微博:BYSocket豆瓣:BYSocketReprint it anywhere u want.文章Points:1、介绍RESTful架构风格2、Spring配置CXF3、三层初设计,实现WebService接口层4、撰写HTTPClient 客户
Writer :BYSocket(泥沙砖瓦浆木匠)什么是回调?今天傻傻地截了张图问了下,然后被陈大牛回答道“就一个回调…”。此时千万个草泥马飞奔而过(逃哈哈,看着源码,享受着这种回调在代码上的作用,真是美哉。不妨总结总结。一、什么是回调回调,回调。要先有调用,才有调用者和被调用者之间的回调。所以在百
Writer :BYSocket(泥沙砖瓦浆木匠)一、什么大小端?大小端在计算机业界,Endian表示数据在存储器中的存放顺序。百度百科如下叙述之:大端模式,是指数据的高字节保存在内存的低地址中,而数据的低字节保存在内存的高地址中,这样的存储模式有点儿类似于把数据当作字符串顺序处理:地址由小向大增加
What is a programming language? Before introducing compilation and decompilation, let&#39;s briefly introduce the Programming Language. Programming la
Writer :BYSocket(泥沙砖瓦浆木匠)微 博:BYSocket豆 瓣:BYSocketFaceBook:BYSocketTwitter :BYSocket泥瓦匠喜欢Java,文章总是扯扯Java。 I/O 基础,就是二进制,也就是Bit。一、Bit与二进制什么是Bit(位)呢?位是CPU
Writer:BYSocket(泥沙砖瓦浆木匠)微博:BYSocket豆瓣:BYSocket一、前言 泥瓦匠最近被项目搞的天昏地暗。发现有些要给自己一些目标,关于技术的目标:专注很重要。专注Java 基础 + H5(学习) 其他操作系统,算法,数据结构当成课外书博览。有时候,就是那样你越是专注方面越