码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • MyBatis学习:$占位符的使用


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

    目前我本人正在学习MyBatis框架,在原先了解并且懵懵懂懂使用的基础上,开始系统正式的学习。阐述了MVC架构模式和三层架构,明晰了在Web项目中的普遍编码层次,回顾了JDBC连接数据库,建立了使用MyBatis和MySQL的Maven项目,解释了STDOUT_LOGGING日志和手动提交事务,记录了MyBatis中#占位符的使用方法,回顾了MyBatis执行SQL语句的过程和使用到的一些重要类和接口,记录了将固定化的代码整合到一个工具类MyBatisUtil中,以减少代码量。记录了dao层接口的实现以及为什么要实现它。记录了MyBatis动态代理和使用动态代理的要求以及使用了动态代理生成的实现类。记录了MyBatis框架下传参的五种方法,占位符#和$的区别。本篇博客记录一下$占位符的使用方法。

    2、我的上一篇博文

    我上一篇博文记录的是 #占位符和$占位符之间的区别,感兴趣的读者可以前往查阅,链接如下所示:

    MyBatis学习:#占位符和 $占位符的区别_你是我的日月星河的博客-CSDN博客目前我本人正在学习MyBatis框架,在原先了解并且懵懵懂懂使用的基础上,开始系统正式的学习。阐述了MVC架构模式和三层架构,明晰了在Web项目中的普遍编码层次,回顾了JDBC连接数据库,建立了使用MyBatis和MySQL的Maven项目,解释了STDOUT_LOGGING日志和手动提交事务,记录了MyBatis中#占位符的使用方法,回顾了MyBatis执行SQL语句的过程和使用到的一些重要类和接口,记录了将固定化的代码整合到一个工具类MyBatisUtil中,以减少代码量。...https://blog.csdn.net/weixin_46281472/article/details/126186006

    3、使用${ }占位符替换原先的#{  }占位符

    直接粘贴代码:

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

    1. //${ }占位符的使用
    2. List queryStudent(@Param(value = "name") String name);

    mapper.xml文件代码:

    1. <select id="queryStudent" resultType="com.dcy.domain.Student">
    2. select * from student where name=${name}
    3. select>

    在Main方法中进行测试:

    1. //测试使用${}占位符
    2. SqlSession sqlSession= MyBatisUtil.getSqlSession();
    3. StudentDao studentDao = sqlSession.getMapper(StudentDao.class);
    4. //下面的一定要加上一对单引号, 因为${ }占位符是将字符串直接相加的
    5. List students = studentDao.queryStudent("'江小白'");
    6. System.out.println(students);

    注意:传过去的参数是一个字符串,一定要加上一对单引号,要不然会造成错误。因为 ${  }的原理就是直接字符串相加的。如果不使用单引号,上面的示例代码生成的SQL语句就是下面的:

    select  *   from student  where  name=江小白

    很明显,这个SQL语句是不对的,是不会执行的!!!

    非常不建议按照上面的使用方法,把#{  }替换掉,这样存在注入攻击的风险,效率也不高。

    4、${  }占位符经常表示表名或者是列名(经常使用)

    思考这样的一个需求:

    要将查询出来的数据,按照某一列升序或降序排列。具体是哪一个列,是由前端传递过来的。在这样的场景下,就必须要使用到  ${  }占位符,而不能使用#{  }占位符。因为:#{  }占位符使用的时候,如果传递过去的是一个字符串,那么最终生成的SQL语句,会自动使用双引号包裹住字符串。

    直接粘贴代码,按照name列排序查询出来的数据:

    dao层接口方法代码:

     List queryStudentOrderByColume(String colume);

    mapper.xml代码:

    1. <select id="queryStudentOrderByColume" resultType="com.dcy.domain.Student">
    2. select * from student order by ${colume}
    3. select>

    在Main方法中的测试代码:

    1. //测试使用${}占位符
    2. SqlSession sqlSession= MyBatisUtil.getSqlSession();
    3. StudentDao studentDao = sqlSession.getMapper(StudentDao.class);
    4. List studentList = studentDao.queryStudentOrderByColume("name");
    5. System.out.println(studentList);

    5、我的下一篇博文

  • 相关阅读:
    实例分享:低投资也可实现的企业信息化综合运维管理
    55 黑客攻击
    华为云 云耀云服务器L实例评测|使用宝塔一键部署自己专属网站
    十六、商城 - 品牌管理-CRUD(4)
    基于JavaWeb技术的在线考试系统设计与实现
    Axure绘制App引导页
    《认知驱动》读后感:从输入到输出
    本质安全设备标准(IEC60079-11)的理解(一)
    【CSS3】CSS3 3D 转换 ① ( CSS3 3D 转换简介 | 3D 物体与 2D 物体区别 | 3D 空间坐标系 | 常用的 3D 转换属性 | 3D 位移转换语法 | 代码示例 )
    棒球训练的目的·棒球4号位
  • 原文地址:https://blog.csdn.net/weixin_46281472/article/details/126189174
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号