Mybatis参数传递

Mybatis是一个优秀的基于java的持久层框架,它内部封装了jdbc。采用ORM思想

对象关系映射(Object Relational Mapping,简称ORM,或O/RM,或O/R mapping),
简单的说:就是把数据库表和实体类及实体类的属性对应起来,让我们可以操作实现操作数据库表

单参数传递

1.如果只有一个参数,Mybatis不做任何特殊处理,可以直接取出参数值赋给xml文件如: #{id}(mybatis会自动进行参数的赋值)

mysql 入参是map foreach mybatis入参_mybatis


mysql 入参是map foreach mybatis入参_封装_02


mysql 入参是map foreach mybatis入参_xml_03


2.

多参数传递

a. JavaBean传递参数,参数大于5建议使用

mysql 入参是map foreach mybatis入参_mybatis_04


我们要把传递的参数封装成一个javabean来传递,接口中将要传递的参数封装

mysql 入参是map foreach mybatis入参_封装_05


写一个构造方法

mysql 入参是map foreach mybatis入参_xml_06


在公共类中将类实例化

mysql 入参是map foreach mybatis入参_xml_07


Xml文件中:#{属性名}去除传入的实体的属性值

b Map接口,可读性差,不使用

如果参数个数比较少,而且没有对应的JavaBean,可以封装成Map.xml中:#{key}取出map中对应的值

mysql 入参是map foreach mybatis入参_mybatis_08


在接口中将参数定义成Map类型

mysql 入参是map foreach mybatis入参_xml_09


之后要在这个地方先定义一个Map,在param当中赋我们需要查询的值,通过key和value

mysql 入参是map foreach mybatis入参_封装_10


在xml文件中的值要和map中定义的Key要相同的,也就是name要对应

mysql 入参是map foreach mybatis入参_封装_11


最后将封装好的map传递给参数

c 通过注解@param(自动封装在Map集合中,参数小于5最佳)

以上两种方式都需要我们手动的创建Map及对象,不简洁,可以使用@param注解,可以明确指定封装参数时map的key

在接口中定义的数据类型前面加一个注解**@param**,后面加上我们传递的参数名字,这个名字要和xml文件中的名字对应 @param注解的作用是给参数命名,参数命名后就能根据名字得到参数值,将正确的数据传入sql语句中

mysql 入参是map foreach mybatis入参_参数传递_12


mysql 入参是map foreach mybatis入参_xml_13


将参数传递进来

mysql 入参是map foreach mybatis入参_封装_14

3.集合():在Mapper接口方法入参处使用@parameter进行标注(Collection、List、Array作为参数,但是有一定的规则)