码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • MyBatis学习:动态SQL中<where>标签的使用


    1、本篇博文的背景和目的

    我本人正在学习MyBatis框架,在原先了解并且懵懵懂懂使用的基础上,开始系统正式的学习。阐述了MVC架构模式和三层架构,回顾了JDBC连接数据库,建立了使用MyBatis和MySQL的Maven项目,解释了STDOUT_LOGGING日志和手动提交事务,记录了MyBatis中#占位符的使用方法,回顾了MyBatis执行SQL语句的过程和使用到的一些重要类和接口,记录了将固定化的代码整合到一个工具类MyBatisUtil中,以减少代码量。记录了dao层接口的实现以及为什么要实现它。记录了MyBatis动态代理和使用动态代理的要求以及使用了动态代理生成的实现类。记录了MyBatis框架下传参的五种方法,占位符#和$,如何自定义别名,resultType属性的使用方法,如何处理数据库中列名和JAVA对象属性名不一致的情况,如何组装传递模糊查询的条件(一共有两种方式),动态SQL中if标签的使用。本篇博文记录一下动态SQL中标签的使用。

    2、我的上一篇博文

    我上一篇博文记录的是  标签单独使用的情况,感兴趣的读者可以移步查阅,链接如下所示:

    MyBatis学习:动态SQL中<if>标签的使用_你是我的日月星河的博客-CSDN博客什么是动态SQL呢?简单的说,就是同一个dao 的方法,根据不同的条件,可以表示不同的SQL语句,主要是 where部分有变化。where条件变化了,那么查询出来的结果肯定就不一样了啊;动态SQL的实现,我们是使用不同的MyBatis的标签来实现的,主要实现的标签有 :,,, 这四个标签。在使用动态SQL的时候, dao方法的形参要使用 JAVA的对象;使用JAVA对象来表示参数;...https://blog.csdn.net/weixin_46281472/article/details/126567400

    3、为什么要使用where标签

    使用where标签是为了规避单独使用 if 标签所存在的不足:单独使用if标签的时候,需要在SQL语句中额外加上 where 关键字,但是:如果全部的if标签的条件都不满足,那么还存在着where关键字,那么就会造成SQL语法错误。此外,还可能会多一个少一个  or或者是and  这样的连接词。

    以上的这些问题,使用  标签都可以完美的避开!!

    4、where标签的语法

    where标签里面是一个或者是多个 if 标签;当有一个 if标签的判断条件是 true,这个时候 where标签会转换为 WHERE关键字,然后附加到SQL语句的后面;如果 if标签没有一个是 true,那么就会忽略 where和里面的 if。

    where的语法规则如下:

    主SQL语句

    SQL语句

    SQL语句

    where标签会删掉紧跟着它之后的 一个 or或者是 and,这样我们就不需要考虑多加了一个 or或者是and,就可以 每一个if标签前面都加上 and或者 or ;

    5、使用where标签的实例代码

    dao层接口方法代码,如下所示:

    1. //使用where标签和if标签
    2. List selectWhere(Student student);

    mapper.xml文件代码,如下所示:

    1. <select id="selectWhere" resultType="com.dcy.domain.Student">
    2. select * from student
    3. <where>
    4. <if test="name!=null and name!=''">
    5. or name=#{name}
    6. if>
    7. <if test="age!=null and age!=''">
    8. or age > #{age}
    9. if>
    10. where>
    11. select>

    可以明显看到,我们上面的代码中,SQL语句里面没有使用where关键字,这是因为使用了标签,MyBatis自动帮助我们判断是不是需要加上where关键字。第一个if标签中的连接词or是可有可无的,即使有,MyBatis也会将这个连接词删除,因为本来就是语法错误。

    在Main方法中进行必要的测试,代码如下:

    1. package com.dcy;
    2. import com.dcy.dao.StudentDao;
    3. import com.dcy.domain.Student;
    4. import com.dcy.utils.MyBatisUtil;
    5. import org.apache.ibatis.session.SqlSession;
    6. import java.util.List;
    7. public class Starter02 {
    8. public static void main(String[] args) {
    9. SqlSession sqlSession = MyBatisUtil.getSqlSession();
    10. StudentDao studentDao = sqlSession.getMapper(StudentDao.class);
    11. Student student=new Student();
    12. student.setName("马小");
    13. student.setAge(22);
    14. List students = studentDao.selectWhere(student);
    15. System.out.println(students);
    16. }
    17. }

    上面的代码是:筛选出所有学生信息中,名字是马小或者年龄大于22岁的。

    运行结果这里我就不粘贴了,跟上一篇博文的运行结果相同。

    6、本篇博文所用的示例代码所在的gitee仓库地址

    7、我的下一篇博文

  • 相关阅读:
    【编程题】【Scratch三级】2021.12 分身术
    介绍Node.js中fs模块 代码和注释。
    前端加密、解密
    46.drf过滤、搜索、排序
    使用福禄克CFP光纤测试仪进行Tier 1和Tier 2光纤测试
    制作一个简单HTML个人网页网页(HTML+CSS)大话西游之大圣娶亲电影网页设计
    2 万字 + 30 张图 | 细聊 MySQL undo log、redo log、binlog 有什么用?
    Nacos安装
    GDB调试器(linux)
    WPF中加载GIF
  • 原文地址:https://blog.csdn.net/weixin_46281472/article/details/126574781
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号