mybatis的动态SQL以及连接池详解
mybatis动态SQL及连接池
mybatis根据传入参数的不同来查询。
<select id="findByCondition" parameterType="com.domain.User" resultType="com.domain.User"> select * from users where 1=1 <if test="name != null"> and name= #{name} </if> </select>
如果太多的话,就不写where1=1.在if外面嵌套if标签。
<select id="findByCondition" parameterType="com.domain.User" resultType="com.domain.User"> select * from users <where> <if test="name != null"> and name= #{name} </if> </where> </select>
同时,第一个if语句中的and将会被省略!!!
mybatis中的范围查询,in
mybatis范围查询,例如select * from users where age in (11,12,13);
外部定义一个包装类,包装ages作为属性,下列以id为例子(在外部定义集合来包装)
<select id="findByRange" parameterType="com.domain.QueryVo" resultType="com.domain.User"> select * from users <where> //where子句的开头,and或者是or,将会被where元素去除。 <if test="ids != null and ids.size()>0">这里的判断条件是Java语句 <foreach collection="ids" open="and id in (" close=")" item="id" separator=","> #{id} </foreach> </if> </where> </select>
SQL语句 select 字段 from where id in{?}
<foreach>标签用于遍历集合,它的属性;
Collection
代表要遍历的集合元素(属性名称)open
代表语句的开始部分close
代表语句的结束部分item
代表遍历集合的每个元素,生成的变量名sperator
代表元素之间的分割符
连接池
连接池:在实际开发中使用,可以减少我们获取连接所消耗的时间。
mybatis连接池提供了3种方式的配置
在主配置文件中的DataSource属性中配置
type
取值 POOLED采用传统的javax.sql.DataSource规范中的连接池UNPOLLED
虽然实现了DataSource的标准,但是没有使用池的概念(Connection对象)JNDI
使用服务器提供的jndi技术来取得DataSource对象。注意:如果不是web工程和maven的war工程,是不可使用的。
备注:mybatis中事务的操控,底层是通过操控Connection对象设置的。
POOLED
:从池中拿出连接,最后把连接放回池里。UNPOOLED
创建连接,结束连接(jdbc连接方式)
动态sql与多表的连接查询
动态sql
① where和if标签
② foreach循环标签
注意事项:
③ 批量添加
④ selectKey
多表的连接查询
① 多对一查询
A). 建表时,外键一定是建在多的一端。
B). 在多的一端的实体类中创建一个一的一端的对象属性。
C). 连接查询的sql语句
- ①select … from 表1 left join 表2 on 连接条件。连接条件一般就是外键=指向的主键。
- ② resultMap
i. id,result配置一般的属性
ii. association标签配置多余的字段,property和javatype属性。子标签id和result
② 多对一查询如何做到修改功能
③ 一对多查询
与多对一查询不同的地方:
A)创建实体类时,在一的一端创建一个List属性,List中放的是多的一端的对象。
B)详细的resultMap配置
小结
一对多的查询用的相对少一些。在查询一的一端的同时查询展示外键与一的 一端的主键相同的数据。
例:查询部门表同时查询展示所有属于该部门的员工。
多对以的查询用的相对多一些。在查询多的一端的同时查询展示主键与多的一端的外键相同的数据。例:查询员工表同时查询展示该员工所属的部门信息。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持猪先飞。
原文出处:https://blog.csdn.net/weixin_46083389/article/details/113572
相关文章
- 这篇文章主要介绍了Mybatis Plus select 实现只查询部分字段的操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教...2021-09-01
- 这篇文章主要介绍了解决Mybatis 大数据量的批量insert问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-01-09
- 这篇文章主要介绍了Redis连接池配置及初始化实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-03-29
- 这篇文章主要介绍了mybatis的Configuration详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-11-04
mybatis 返回Integer,Double,String等类型的数据操作
这篇文章主要介绍了mybatis 返回Integer,Double,String等类型的数据操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-11-25- 数据库中的数据删除会分为两种:物理删除 和 逻辑删除,接下来通过本文给大家介绍MyBatis-Plus的物理删除和逻辑删除使用场景分析,感兴趣的朋友一起看看吧...2021-09-25
Springboot如何使用mybatis实现拦截SQL分页
这篇文章主要介绍了Springboot使用mybatis实现拦截SQL分页,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下...2020-06-19- 这篇文章主要介绍了Mybatis执行update失败的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教...2021-09-01
- 这篇文章主要介绍了Mybatis plus中使用in查询出错的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2020-08-06
- Mybatis-Plus是一个Mybatis的增强工具,它在Mybatis的基础上做了增强,却不做改变,Mybatis-Plus是为简化开发、提高开发效率而生,但它也提供了一些很有意思的插件,比如SQL性能监控、乐观锁、执行分析等,下面一起看看mybatis-plus雪花算法自动生成机器id原理解析...2021-06-04
解决Mybatis中mapper.xml文件update,delete及insert返回值问题
这篇文章主要介绍了解决Mybatis中mapper.xml文件update,delete及insert返回值问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-11-23- 这篇文章主要介绍了Mybatis用注解写in查询的实现方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教...2021-07-13
Mybatis之Select Count(*)的获取返回int的值操作
这篇文章主要介绍了Mybatis之Select Count(*)的获取返回int的值操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-11-23- 这篇文章主要介绍了Mybatis和Mybatis-Plus时间范围查询方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教...2021-08-06
Springboot mybatis plus druid多数据源解决方案 dynamic-datasource的使用详解
这篇文章主要介绍了Springboot mybatis plus druid多数据源解决方案 dynamic-datasource的使用,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2020-11-18- 这篇文章主要介绍了mybatis Map查询结果下划线转驼峰的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-09-24
Mybatis Plus 字段为空值时执行更新方法未更新解决方案
这篇文章主要介绍了Mybatis Plus 字段为空值时执行更新方法未更新解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-09-03关于IDEA 2020使用 mybatis-log-plugin插件的问题
这篇文章主要介绍了关于IDEA 2020使用 mybatis-log-plugin插件的问题,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2020-11-10- 这篇文章主要介绍了Mybatis返回结果封装map过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下...2020-09-19
springboot配置多数据源后mybatis拦截器失效的解决
这篇文章主要介绍了springboot配置多数据源后mybatis拦截器失效的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教...2021-09-23