欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

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

程序员文章站 2022-05-18 15:29:33
...

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>