软件工程应用与实践(4)——数据访问层之参数的传递

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));
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值