MyBatis获取参数的方式

1 MyBatis获取参数值的两种方式:${}和#{}
2 ${}的本质就是字符串拼接,#{}的本质就是占位符赋值
3 ${}使用字符串拼接的方式拼接sql,若为字符串类型或日期类型的字段进行赋值时,需要手动加单引号;但是#{}使用占位符赋值的方式拼接sql,此时为字符串类型或日期类型的字段进行赋值时,可以自动添加单引号

下列图片中用到的userMapper为创建的一个工具类。
image

----获取单个参数
这种情况可以直接使用${}和#{}的方式获取参数的值,${}需要手动加单引号。
image
image
image

----获取多个参数
若mapper接口中的方法参数为多个时,此时MyBatis会自动将这些参数放在一个map集合中。

  1. 以arg0,arg1...为键,以参数为值;
  2. 以param1,param2...为键,以参数为值;
  • 因此只需要通过${}和#{}访问map集合的键就可以获取相对应的值,注意${}需要手动加单引号。
  • 使用arg或者param都行,要注意的是,arg是从arg0开始的,param是从param1开始的

image
image
image

----获取Map集合类型的参数
若mapper接口中的方法需要的参数为多个时,此时可以手动创建map集合,将这些数据放在map中只需要通过${}和#{}访问map集合的键就可以获取相对应的值,注意${}需要手动加单引号
image
image
image

----获取实体类类型的参数
若mapper接口中的方法参数为实体类对象时此时可以使用${}和#{},通过访问实体类对象中的属性名获取属性值,注意${}需要手动加单引号
image
image
image

----使用@Param表示获取参数

  • 可以通过@Param注解标识mapper接口中的方法参数,此时,会将这些参数放在map集合中。
    1. 以@Param注解的value属性值为键,以参数为值;
    2. 以param1,param2...为键,以参数为值;
  • 只需要通过${}和#{}访问map集合的键就可以获取相对应的值,注意${}需要手动加单引号。
    image
    image
    image
posted @   wzh_Official  阅读(37)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~
点击右上角即可分享
微信分享提示