文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

mybatis的动态SQL以及连接池详解

2024-04-02 19:55

关注

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>标签用于遍历集合,它的属性;

连接池

连接池:在实际开发中使用,可以减少我们获取连接所消耗的时间。

mybatis连接池提供了3种方式的配置

在主配置文件中的DataSource属性中配置

备注:mybatis中事务的操控,底层是通过操控Connection对象设置的。

动态sql与多表的连接查询

动态sql

① where和if标签

在这里插入图片描述

② foreach循环标签

在这里插入图片描述

注意事项

在这里插入图片描述

③ 批量添加

在这里插入图片描述

④ selectKey

在这里插入图片描述

多表的连接查询

① 多对一查询

A). 建表时,外键一定是建在多的一端。

B). 在多的一端的实体类中创建一个一的一端的对象属性。

C). 连接查询的sql语句

i. id,result配置一般的属性

ii. association标签配置多余的字段,property和javatype属性。子标签id和result

在这里插入图片描述

② 多对一查询如何做到修改功能

在这里插入图片描述

③ 一对多查询

与多对一查询不同的地方:

A)创建实体类时,在一的一端创建一个List属性,List中放的是多的一端的对象。

B)详细的resultMap配置

在这里插入图片描述

小结

一对多的查询用的相对少一些。在查询一的一端的同时查询展示外键与一的 一端的主键相同的数据。

例:查询部门表同时查询展示所有属于该部门的员工。

多对以的查询用的相对多一些。在查询多的一端的同时查询展示主键与多的一端的外键相同的数据。例:查询员工表同时查询展示该员工所属的部门信息。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     801人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     348人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     311人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     432人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     220人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯