不管我们在做数据库作业或者任务还是当时的仅靠jdbc来写一个管理系统的时候,sql语句需要一些参数,从而来实现模糊查询,精确查询,插入数据,更新数据和删除数据。这些参数,在mybatis里面,又该如何使用呢?我总结了一下五点:

  • 单个参数的绑定:

这个和上一篇的用法是一样的,我们直接在mapper文件里面用#{}代替参数,就可以完成单个参数绑定,例如代码:

mapper.xml文件:


  1. <select id="findById" resultType="Teacher">
  2. select * from teacher where tid=#{tid}
  3. </select>

在dao层的接口里面,只需要写上对应的方法:

public Teacher findById(int tid);

这样,直接用sqlsession去读取这个dao的接口,然后调用这个方法,就可以实现单个参数的传递了。

  • 多个参数绑定:

如果一个sql语句的查询条件有多个的话,就需要多个参数的绑定了。

  • 多个参数绑定:索引传递

在mapper文件中:


  1. <select id="findByNameAndCourseWithIndex" resultType="Teacher">
  2. select * from teacher where tname=#{0} and tcourse=#{1}
  3. </select>

在dao层的接口里面:

public Teacher findByNameAndCourseWithIndex(String tname,String tcourse);

这样就实现了根据索引值来传递参数的问题。

  • 多个参数绑定:注解绑定

除了索引,我们mybatis还提供了注解的方式来传递参数

mapper文件中:


  1. <select id='findByNameAndCourseWithBind' resultType="Teacher">
  2. select * from teacher where tname=#{tname} and tcourse=#{tcourse}
  3. </select>

dao层的接口:

public Teacher findByNameAndCourseWithBind(@Param("tname")String tname,@Param("tcourse")String tcourse);

可以看到,mapper文件中的#{}里面的参数,用@Param()绑定给了dao层的方法,而#{}和@Param()需要一致。这样就实现了参数通过注解的方式绑定。

  • 多个参数绑定:map绑定

利用map,来传递参数,我们知道map是一个键值对形式存储信息的集合,所以利用map也可以实现参数的绑定

mapper文件代码:


  1. <select id="findByNameAndCourseWithMap" resultType="Teacher">
  2. select * from teacher where tname=#{tname} and tcourse=#{tcourse}
  3. </select>

dao层接口文件代码:

public Teacher findByNameAndCourseWithMap(Map paramMap);

在调用接口去使用这个方法的时候,我们需要用到put()方法,来将参数传递过去,例如这里就是paramMap.put("tname","张三")这样一来,就好理解了,键值对的存在,也就形成了一个实参和形参的绑定。

  • 多个参数绑定:直接传递

和单个参数传递一样,我们可以使用直接传递的方法去传递多个参数

mapper文件:


  1. <select id="findByNameAndCourseWithObject" resultType="Teacher" >
  2. select * from teacher where tname=#{tname} and tcourse=#{tcourse}
  3. </select>

dao层接口:

这样一来,我们就也能实现一种参数的传递。

不过要注意的是,mybatis中的SQL接受的参数有基本的数据类型,对象,List,数组和Map,无论传递那种参数给mybatis,都会将参数放在一个Map中,如果传入基本类型:变量名作为key,变量值作为value 此时生成的map只有一个元素。如果传入对象: 对象的属性名作为key,属性值作为value,如果传入List: "list"作为key,这个List是value (这类参数可以迭代,利用标签实现循环)如果传入数组: "array"作为key,数组作为value(同上)如果传入Map: 键值不变。

git源码地址:https://github.com/yueyue123123/mybatisDemo.git

原文地址:https://blog.csdn.net/u010159380/article/details/82255461

mybatis第二篇—参数绑定的更多相关文章

  1. C#语法糖之第二篇: 参数默认值和命名参数 对象初始化器与集合初始化器

    今天继续写上一篇文章C#4.0语法糖之第二篇,在开始今天的文章之前感谢各位园友的支持,通过昨天写的文章,今天有很多园友们也提出了文章中的一些不足,再次感谢这些关心我的园友,在以后些文章的过程中不断的完 ...

  2. Mybatis第二篇【CRUD、分页】

    完成CRUD操作 我们在上一篇中已经简单知道了Mybatis是怎么使用的以及工作流程了,这次我们使用Mybatis来完成CRUD的操作,再次巩固Mybatis的开发步骤以及一些细节 包与类之间的结构 ...

  3. 深入理解this机制系列第二篇——this绑定优先级

    前面的话 上一篇介绍过this的绑定规则,那如果在函数的调用位置上同时存在两种以上的绑定规则应该怎么办呢?本文将介绍this绑定的优先级 显式绑定 pk 隐式绑定 显式绑定胜出 function fo ...

  4. 持久层之 MyBatis: 第二篇 :动态SQL And多表查询

    MyBatis入门到精通 完整CRUD UserDaoImpl 编写UserDao对应的UserDaoMapper.xml 添加UserDao的测试用例 编写UserDao的测试用例 解决数据库字段名 ...

  5. Vue.js学习笔记 第二篇 样式绑定

    Class绑定的对象语法 <!DOCTYPE html> <html> <head> <meta charset="utf-8"> ...

  6. JAVAEE——SpringMVC第一天:介绍、入门程序、架构讲解、SpringMVC整合MyBatis、参数绑定、SpringMVC和Struts2的区别

    1. 学习计划   第一天 1.SpringMVC介绍 2.入门程序 3.SpringMVC架构讲解 a) 框架结构 b) 组件说明 4.SpringMVC整合MyBatis 5.参数绑定 a) Sp ...

  7. 泛型2(lambda表达式/参数绑定)

    lambda 表达式: Lambda表达式完整的声明格式如下: [capture list] (params list) mutable exception-> return type { fu ...

  8. 深入理解javascript函数系列第二篇——函数参数

    × 目录 [1]arguments [2]内部属性 [3]函数重载[4]参数传递 前面的话 javascript函数的参数与大多数其他语言的函数的参数有所不同.函数不介意传递进来多少个参数,也不在乎传 ...

  9. SpringMVC第四篇【参数绑定详讲、默认支持参数类型、自定义参数绑定、RequestParam注解】

    参数绑定 我们在Controller使用方法参数接收值,就是把web端的值给接收到Controller中处理,这个过程就叫做参数绑定- 默认支持的参数类型 从上面的用法我们可以发现,我们可以使用req ...

随机推荐

  1. Unity开发一些实用的提高效率的技巧

    该文章参考总结自Unity微信官方 原文: Unity小技巧介绍 1 如果编辑器意外崩溃了,但场景未保存,这时可以打开工程目录,找到/Temp/_Backupscenes/文件夹,可以看到有后缀名为. ...

  2. [转]springmvc+mybatis需要的jar包与详解

    1.antlr-2.7.6.jar:  项目中没有添加,hibernate不会执行hql语句 2.Aopalliance.jar: 这个包是AOP联盟的API包,里面包含了针对面向切面的接口,通常Sp ...

  3. 配置文件一mybatis-config.xml

    <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE configuration PUBLIC & ...

  4. JavaScript 对象与函数

    对象参考手册 Array Boolean Date Math Number String RegExp Global 前言 在js中什么都是对象(包括函数). 函数是用来实现具体功能的代码,用一种方式 ...

  5. csps模拟87888990部分题解

    题面:https://www.cnblogs.com/Juve/articles/11752338.html https://www.cnblogs.com/Juve/articles/1175241 ...

  6. 树的直径+质因子——好题!cf1101D

    /* 因为质因子很少 状态转移时用dp[u][i]表示结点u的第i个质因子所在的最大深度即可 等价于带限制的求直径 */ #include<bits/stdc++.h> #include& ...

  7. LUOGU P2290 [HNOI2004]树的计数(组合数,prufer序)

    传送门 解题思路 \(prufer\)序,就是所有的不同的无根树,都可以转化为唯一的序列.做法就是每次从度数为\(1\)的点中选出一个字典序最小的,把这个点删掉,并把这个点相连的节点加入序列,直到只剩 ...

  8. echarts renderItem-在区间段内展示连续数据

    一.需求背景: 贴图说明:要求数据在不同类型的区间段内展示. 二.实现思路及代码 实现方法: 利用echarts的自定义配置:option.series[i].type='custom'中的rende ...

  9. Python Flask高级编程之从0到1开发《鱼书》精品项目 ✍✍✍

    Python Flask高级编程之从0到1开发<鱼书>精品项目  一 .安装环境我们使用 flask web框架,并用 sqlalchemy来做数据库映射,并使用 migrate做数据迁移 ...

  10. Oracle如何用单字段或多字段进行查重

    最近在整理数据形成信用报告,发现重复的数据真的多,梳理都好久.我就做个笔记把去掉重复数据的方法整理下来.方便我后期查阅. 我将我目前已知的两种去重方法分为:视图去重和表去重.原理就是有无rowid这个 ...