MyBatis中Dao接口方法和mapper文件中的参数传递(最常用的三种方法)

MyBatis中Dao接口方法和mapper文件中的参数传递(最常用的三种方法)

  1. 当Dao接口方法中的参数是一个简单类型的参数
package com.bjpowernode.dao;

import com.bjpowernode.domain.Student;

public interface StudentDao {

    public Student selectById(Integer id);

    //dao接口中方法的形参是一个简单类型的形参
    //简单类型: java基本数据类型和String
    Student selectByEmail(String email);

}
    <!--
       dao接口中方法的形参是一个简单类型的参数
       mapper文件中,获取这个参数,使用#{任意字符}
    -->
    <select id="selectByEmail" resultType="com.bjpowernode.domain.Student">
        select id,name,email,age from student where email=#{studentEmail}
    </select>
  1. 当Dao接口方法中的参数有多个简单类型的参数
    /*Dao接口方法中有多个简单类型参数
    * 使用@Param命名参数,注解是mybatis提供的
    * 位置:在形参定义的前面
    * 属性:value可以取值为自定义的参数名称
    */

    List<Student> selectByNameOrAge(@Param("myname") String name,
                                    @Param("myage") Integer age);

    <!--Dao接口方法中有多个简单类型参数
        当使用了@Param命名后,例如@Param('myname').
        在mapper文件中,使用#{命名的参数},例如 #{myname}
    -->
    <select id="selectByNameOrAge" resultType="com.bjpowernode.domain.Student">
        select id,name,email,age from student where name=#{myname} or age=#{myage}
    </select>
  1. 在Dao接口方法中也可以使用一个对象作为形参

    当dao接口方法的形参是一个java对象时,这个java对象表示多个参数。

    java对象:

    public class Student {
    
        private Integer id;
        private String name;
        private String email;
        private Integer age;
        
        //get set方法
    }
    

    dao接口中的方法定义:

    /*
    *   一个java对象作为参数(对象有属性,每个属性有set,get方法)
    *
    * */
    List<Student> selectByObject(Student student);

​ mapper文件:

    <!--
        一个java对象作为方法的参数,在mapper文件中使用对象的属性作为参数值使用
        简单的语法:#{属性名} , mybatis调用此属性的getXXX()方法
    -->
    <select id="selectByObject" resultType="com.bjpowernode.domain.Student">
        select id,name,email,age from student where name=#{name} or age=#{age}
    </select>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值