2021SC@SDUSC
一、概念
从 java 代码中把查询参数传递到 mapper.xml 文件中的sql语句中,查询出符合需求的数据。
二、具体实现
本项目中主要使用对象进行参数传递(下列第三种),既然聊到了参数传递,我便将几种参数传递的方式都罗列出来。
1,一个简单参数
Dao 接口中方法的参数只有一个简单类型(java 基本类型和 String),占位符 #{ 任意 字符 },和方法的参数名无关。
dao接口方法:
UserselectById(int id);
mapper 文件:
<select id="selectById" resultType="com.sdu.nurse.dao.UserDao">
select id,name,email,age from User where id=#{UserId}
</select>
测试方法:
@Test
public void testSelectById(){
// 一个参数
User user = UserDao.selectById(1005);
System.out.println(" 查询 id 是 1005 的用户:"+user);
}
2,多个参数- 使用@Param
当 Dao 接口方法多个参数,需要通过名称使用参数。 在方法形参前面加入@Param(“自定义参数名”),mapper 文件使用#{自定义参数名}。
dao接口方法:
List selectMultiParam(@Param(“personName”) String name,
@Param(“personAge”) int age);
mapper 文件:
<select id="selectMultiParam" resultType="com.sdu.nurse.dao.UserDao">
select id,name,email,age from User where name=#{personName} or age =#{personAge}
</select>
测试方法:
@Test
public void testSelectMultiParam(){
List<User> userList = userDao.selectMultiParam(" 李力",20);
userList.forEach( user -> System.out.println(user));
}
3,多个参数- 使用对象
使用 java 对象传递参数, java 的属性值就是 sql 需要的参数值。 每一个属性就是一个参数。语法格式: #{ property,javaType=java 中数据类型名,jdbcType=数据类型名称 } javaType, jdbcType 的类型 MyBatis 可以检测出来,一般不需要设置。常用格式 #{ property }.
创建保存参数值的对象 QueryParam
public class QueryParam {
private String queryName;
private int queryAge;
//set , get 方法
}
dao接口方法:
List selectMultiObject(QueryParam queryParam);
mapper 文件:
<select id="selectMultiObject" resultType="com.sdu.nurse.dao.UserDao">
select id,name,email,age from User where name=#{queryName} or age =#{queryAge}
</select>
<!--或者-->
<select id="selectMultiObject" resultType="com.sdu.nurse.dao.UserDao">
select id,name,email,age from User where name=#{queryName,javaType=string,jdbcType=VARCHAR} or age =#{queryAge,javaType=int,jdbcType=INTEGER}
</select>
测试方法:
@Test
public void selectMultiObject(){
QueryParam qp = new QueryParam();
qp.setQueryName(" 李力");
qp.setQueryAge(20);
List<User> stuList = userDao.selectMultiObject(qp);
userList.forEach( user -> System.out.println(user));
}
4,多个参数- 按位置
参数位置从 0 开始, 引用参数语法 #{ arg 位置 } , 第一个参数是#{arg0}, 第二个是#{arg1}注意:mybatis-3.3 版本和之前的版本使用#{0},#{1}方式, 从 mybatis3.4 开始使用#{arg0}方式。
dao接口方法:
List selectByNameAndAge(String name,int age);
mapper 文件:
<select id="selectByNameAndAge" resultType="com.sdu.nurse.dao.UserDao">
select id,name,email,age from User where name=#{arg0} or age =#{arg1}
</select>
测试方法:
@Test
public void testSelectByNameAndAge(){
// 按位置参数
List<User> userList = userDao.selectByNameAndAge(" 李力",20);
userList.forEach( user -> System.out.println(user));
}