码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • MyBatis学习:使用Map的方法传递参数


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

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

    2、我的上一篇博文

    上一篇博文记录的是按照位置传参的方法,感兴趣的读者可以前往查阅,链接如下:

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

    3、使用Map传参的示例代码

    使用Map形式传递参数,需要保证dao层接口方法的形参是Map类型。

    dao层接口方法入下所示:

    1. //使用map传递参数
    2. List selectStudentByMap(Map map);

    mapper.xml文件中SQL语句的标签代码:

    1. 、
    2. <select id="">
    3.     select * from student where
    4.         name=#{myname} or
    5.         age=#{myage}
    6. select>

    在Main方法中测试代码如下所示:

    1.  public void testSelectByMap(){
    2.         //首先获取我们的SqlSession对象
    3.         SqlSession sqlSession= MyBatisUtil.getSqlSession();
    4.         StudentDao dao = sqlSession.getMapper(StudentDao.class);//这一行就是使用了动态代理
    5.         //我们使用map传递参数
    6.         Map data=new HashMap<>();
    7.         data.put("myname","李思思");
    8.         data.put("myage",20);
    9.         List students = dao.selectStudentByMap(data);
    10.         System.out.println(students);
    11. }

    注意Main测试方法中的  键  和在mapper.xml文件 #{  }  里面的内容。二者是一样的。

    也就是说:只有保证上述二者的一样,这样才能保证顺利传参。

    4、非常不建议使用Map的方法传参

    因为要保证Map中的键 和 mapper.xml中 #{  }里面的内容保持一致。这样在实际开发中是很不现实的!!!

    及其不建议使用!!

    5、下一篇博文

  • 相关阅读:
    网络计算器—————序列化与反序列化
    java计算机毕业设计基于安卓Android的学生个人支出管理APP
    关于Java8 stream的相关使用及解析
    mac 中定时任务执行时的环境不同于手动执行时的环境
    C++中的多态(上)
    redis 队列
    如何修改min.js或者压缩后的js,以便提高代码的可读性。
    MySQL入门
    1、skywalking-介绍
    思科防火墙解析(ASA)
  • 原文地址:https://blog.csdn.net/weixin_46281472/article/details/126179501
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号