Mybatis中@Param的用法和作用详解

编程入门 行业动态 更新时间:2024-10-23 01:42:04

Mybatis中@Param的用法和作用<a href=https://www.elefans.com/category/jswz/34/1770044.html style=详解"/>

Mybatis中@Param的用法和作用详解

@Param用于dao层,是mybatis中的注解
使得mapper.xml中的参数与后台的参数对应上,也增强了可读性

如果两者参数名一致得话,spring会自动进行封装,不一致的时候就需要手动去使其对应上。
即:用注解来简化xml配置的时候,@Param注解的作用是给参数命名,参数命名后就能根据名字得到参数值,正确的将参数传入sql语句中 。

  • 在方法只接受一个参数的情况下,可以不使用@Param。

  • 在方法接受多个参数的情况下,建议一定要使用@Param注解给参数命名。

  • 如果参数是 JavaBean , 则不能使用@Param。

  • 不使用@Param注解时,参数只能有一个,并且不是JavaBean

数据库表结构

 

实体类

/*** mybatis-sql语句测试实体类* @Author: chenyang* @Date: 2021/11/23 15:18* @Description: 测试实体类*/
public class Human {/*** 主键id*/private Integer id;/*** 用户名称*/private String name;/*** 性别 1 男, 2 女*/private String sex;/*** 个人介绍*/private String introduce;/*** 脸型*/private Integer face;private Integer type;private String createTime;private String updateTime;
}

正常的操作

    /*** 根据姓名和性别查找用户,假设查找的结果只有一条* @param name* @param sex* @return*/Human selectHumanByNameAndSex(String name, Integer sex);
    <select id="selectHumanByNameAndSex" resultType="Human">select * from m_human where name=#{name} and sex=#{sex}</select>
    @Testpublic void test4(){Human human = humanDao.selectHumanByNameAndSex("manager", 1);System.out.println(human);}

返回的结果

Human{id=3, name='manager', sex='1', introduce='manager2', face=1, type='1', createTime='2021-11-29 22:52:56', updateTime='null'}

数据库数据

 查询结果无错误

修改dao层抽象方法

     /*** 根据姓名和性别查找用户,假设查找的结果只有一条* @param username* @param sex* @return*/Human selectHumanByNameAndSex(String username, Integer sex);

再次执行Test方法,报错,方法参数和数据库字段对应不上

Caused by: org.apache.ibatis.binding.BindingException: Parameter 'name' not found. Available parameters are [sex, param1, username, param2]

有两种解决办法

第一种是修改xml中的sql语句

    <select id="selectHumanByNameAndSex" resultType="Human">select * from m_human where name=#{username} and sex=#{sex}</select>

第二种是使用@Parm注解

用注解来简化xml配置的时候,@Param注解的作用是给参数命名,参数命名后就能根据名字得到参数值,正确的将参数传入sql语句中

Human selectHumanByNameAndSex(@Param("name") String username, Integer sex);

采用#{}的方式把@Param注解括号内的参数进行引用 

    <select id="selectHumanByNameAndSex" resultType="Human">select * from m_human where name=#{name} and sex=#{sex}</select>

更多推荐

Mybatis中@Param的用法和作用详解

本文发布于:2024-02-05 09:12:07,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1674033.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:详解   作用   Mybatis   Param

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!