这里是修真院后端小课堂,每篇分享文从
【背景介绍】【知识剖析】【常见问题】【解决方案】【编码实战】【扩展思考】【更多讨论】【参考文献】
八个方面深度解析后端知识/技能,本篇分享的是:
【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
更多内容,可以加入IT交流群565734203与大家一起讨论交流
这里是技能树·IT修真院:,初学者转行到互联网的聚集地
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。