Mybatis入参处理

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文件中:#{属性名}去除传入的实体的属性值
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作为参数,但是有一定的规则)

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值