IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> Mybatis中@Param的用法和作用详解 -> 正文阅读

[Java知识库]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>
    @Test
    public 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>

  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2021-11-30 15:28:34  更:2021-11-30 15:31:42 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 3:43:57-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码