在MyBatis的`mapper.xml`文件中,可以使用`parameterType`属性来指定方法的参数类型。`parameterType`属性用于指定传递给映射方法的参数类型,这将影响到MyBatis在映射方法执行时如何处理参数。
以下是三种不同情况下如何在`mapper.xml`中使用`parameterType`实现方法单个传参、对象传参和多参数传参的示例:
1. 方法单个传参:
如果方法只需要一个参数,你可以将`parameterType`设置为具体的Java类型。例如,假设你的方法需要一个整数作为参数:
```xml
XML
<!-- mapper.xml -->
<select id="getEntityById" resultType="Entity" parameterType="int">
SELECT * FROM entity_table WHERE id = #{id}
</select>
```
2. 对象传参:
如果方法需要一个Java对象作为参数,你可以将`parameterType`设置为该Java对象的类名。这样,在SQL语句中可以使用对象的属性来引用参数。
假设有一个Java对象`User`,具有`id`和`username`属性:
```xml
XML
<!-- mapper.xml -->
<select id="getUserByUsername" resultType="User" parameterType="User">
SELECT * FROM user_table WHERE username = #{username}
</select>
```
3. 多参数传参:
如果方法需要多个参数,你可以使用Map或者使用注解来指定参数。如果使用Map,可以将`parameterType`设置为`java.util.Map`。如果使用注解,可以在方法参数前使用`@Param`注解。
使用Map的示例:
```xml
XML
<!-- mapper.xml -->
<select id="getUsersByAgeAndName" resultType="User" parameterType="java.util.Map">
SELECT * FROM user_table WHERE age = #{age} AND username = #{name}
</select>
```
使用注解的示例:
```java
java
// Mapper interface
public interface UserMapper {
List<User> getUsersByAgeAndName(@Param("age") int age, @Param("name") String name);
}
```
```xml
XML
<!-- mapper.xml -->
<select id="getUsersByAgeAndName" resultType="User" parameterType="int">
SELECT * FROM user_table WHERE age = #{age} AND username = #{name}
</select>