MyBatis中Dao接口方法和mapper文件中的参数传递(最常用的三种方法)
程序员文章站
2022-05-18 15:29:33
...
MyBatis中Dao接口方法和mapper文件中的参数传递(最常用的三种方法)
- 当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>
- 当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>
-
在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>
上一篇: java实现定时的三种方法
下一篇: vue router三种方式传递参数