Mybatis参数传递
Mybatis是一个优秀的基于java的持久层框架,它内部封装了jdbc。采用ORM思想
对象关系映射(Object Relational Mapping,简称ORM,或O/RM,或O/R mapping),
简单的说:就是把数据库表和实体类及实体类的属性对应起来,让我们可以操作实现操作数据库表
单参数传递
1.如果只有一个参数,Mybatis不做任何特殊处理,可以直接取出参数值赋给xml文件如: #{id}(mybatis会自动进行参数的赋值)
2.
多参数传递
a. JavaBean传递参数,参数大于5建议使用
我们要把传递的参数封装成一个javabean来传递,接口中将要传递的参数封装
写一个构造方法
在公共类中将类实例化
Xml文件中:#{属性名}去除传入的实体的属性值
b Map接口,可读性差,不使用
如果参数个数比较少,而且没有对应的JavaBean,可以封装成Map.xml中:#{key}取出map中对应的值
在接口中将参数定义成Map类型
之后要在这个地方先定义一个Map,在param当中赋我们需要查询的值,通过key和value
在xml文件中的值要和map中定义的Key要相同的,也就是name要对应
最后将封装好的map传递给参数
c 通过注解@param(自动封装在Map集合中,参数小于5最佳)
以上两种方式都需要我们手动的创建Map及对象,不简洁,可以使用@param注解,可以明确指定封装参数时map的key
在接口中定义的数据类型前面加一个注解**@param**,后面加上我们传递的参数名字,这个名字要和xml文件中的名字对应 @param注解的作用是给参数命名,参数命名后就能根据名字得到参数值,将正确的数据传入sql语句中
将参数传递进来
3.集合():在Mapper接口方法入参处使用@parameter进行标注(Collection、List、Array作为参数,但是有一定的规则)