大家好,我是IT修真院深圳分院第15期的JAVA学员,一枚正直纯洁善良的JAVA程序员。今天给大家分享一下,修真院官网Java任务1,深度思考中的知识点JDBC连接池原理
一、背景介绍
之前刚开始学的时候都是从JDBC开始,就是那几个固定的步骤,加载驱动,创建连接、建立语句这些,这些都是辅助性的手段,大家准备工作做好以后,才能执行SQL语句进行CURD的操作。当然我们写的时候一个表就要把这些东西全部写一遍,十分痛苦。MyBatis就出来了,他是一个持久层的框架,能减少这些重复性的工作,通过mybatis提供的映射方式,自由灵活的生成满足需要的sql语句。MyBatis可以将向preparedStatement中的输入参数自动进行输入映射,将查询结果集灵活映射成java对象
二、知识剖析
动态SQL是MyBatis最强大的特性之一。用于实现动态SQL的主要元素如下:
- if标签
- where标签
- set标签
- choose标签
- foreach标签
if标签
if是mybatis动态SQL中的判断元素,有点类似于Java中的if语句,不同的是这里的if一般常常和test配合使用。
当用户传入的address不为null或者空字符串的时候,会有语句错误,这个时候就需要加入where标签
where标签
where标签经常跟if标签搭配使用,where标签会判断if标签里的条件是否成立,如果有条件成立则会拼接执行该条件下的sql语句。where标签避免所有条件都为空的时候出现“select * from user where ”这种会出错的情况,当然我们也可以在where后面加入“1=1”简单的解决。
set标签
set标签与where标签类似,set标签一般用在update语句中,当我们在update语句里碰到多个字段相关的问题,在这种情况下我们就会用到set标签,他也是判断if标签里的条件是否成立,然后拼接执行sql语句。相当好使。
choose标签
相比于if标签二选一,choose标签就有了第三种选择,或者更多的选择,在映射器的动态语句中使用choose…when…otherwise…这三个元素就能满足不同的业务要求,Mybatis会根据参数的设置进行判断,来拼接组装sql语句,当when标签下无满足条件,则会执行otherwise标签里的语句。
foreach标签
foreach元素是一个循环语句,他的作用是遍历集合,他能够很好的支持数组和List的集合。并对此提供遍历,foreach标签常用于in这样的语法里,进行批量处理,增删改查都可以。
三、常见问题
if标签与choose标签的区别
四、解决方案
if是不管条件成不成立都会执行下一条if;而choose中,如果when中先执行的语句,则不会再往后执行。
五、编码实战
<!--if查询-->
<select id="ListIf" resultType="com.jnshu.entity.Student">
select * from student
<!--加判断条件-->
<if test="name !=null">
where name like concat('%',#{name},'%')
</if>
<!--第一个条件为空的时候,多条件查询会出错-->
<if test="weight != null">
and weight > #{weight}
</if>
</select>
<!--where标签会进行自动判断,如果任何条件都不成立,那么就在SQL语句不会出现where关键字。如果有任何条件成立,会自动去掉多余的-->
<select id="ListWhere" resultType="com.jnshu.entity.Student">
select * from student
<where>
<if test="name !=null">
and name like concat('%',#{name},'%')
</if>
<if test="weight != null">
and weight > #{weight}
</if>
</where>
</select>
<update id="Update" parameterType="com.jnshu.entity.Student">
UPDATE student
<set>
<if test="name !=null">
name = #{name},
</if>
<if test="weight !=null">
weight = #{weight},
</if>
</set>
where id = #{id}
</update>
<!--MyBatis里面没有else标签,但是可以使用when otherwise标签来达到类似的目的-->
<select id="ListChoose" resultType="com.jnshu.entity.Student" >
select * from student
<where>
<choose>
<when test="name != null">
and name like concat('%',#{name},'%')
</when>
<when test="weight != null">
and weight > #{weight}
</when>
<otherwise>
and id < #{id}
</otherwise>
</choose>
</where>
</select>
<select id="ListForeach" resultType="com.jnshu.entity.Student">
select * from student
where name IN
<foreach collection="list" item="item" open="(" separator="," close=")">
#{item}
</foreach>
</select>
六、扩展思考
1.动态SQL还有哪种实现方式?
2.不同版本mybaits使用动态SQL时的差别?
七、参考文献
https://blog.youkuaiyun.com/jpzhu16/article/details/52810747
八、更多讨论
Q1:为什么要使用动态查询
A1:加入用户想查询一个字段那就需要模糊查询,所以我们就使用动态查询,判断用户输入的内容进行相应的查询。
Q2:平时我们插入不用动态标签页没有什么问题
A2:这是因为平时我们不设默认值,一旦设定默认值,还是要使用动态插入的
Q3:标签只能用户update吗?
A3:没有错,因为sql语句本身的set本来就是用于update语句
感谢原作者的文章,此教程是在他之前技术分享的基础上完善而成。