在mybatis中的mapper.xml中如何使用parameterType实现方法单个传参,对象传参,多参数传参.

在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>
相关推荐
IronMurphy2 小时前
SSM拷打第二讲!!!
java·spring·mybatis
祭曦念8 小时前
ArkUI声明式UI入门:从XML到声明式的思维转变
xml·ui·鸿蒙
C+-C资深大佬21 小时前
SSM 框架(Spring + SpringMVC + MyBatis)
java·spring·mybatis
二王一个今1 天前
springboot security 权限控制---循环依赖问题
mybatis
落木萧萧8251 天前
为什么我把 MyBatisGX 设计成现在这样
mybatis·orm
代码旅人ing1 天前
Redis+Spring+MyBatis + 微服务 + 消息队列核心知识点(面试高频题目合集)
redis·spring·mybatis·java-rabbitmq
Devin~Y1 天前
大厂Java面试实录:Spring Boot/Cloud、Kafka、Redis、K8s 可观测性 + RAG/Agent(小Y翻车版)
java·spring boot·redis·spring cloud·kafka·kubernetes·mybatis
ppandss11 天前
JavaWeb从0到1-DAY11-MyBatis入门
java·tomcat·mybatis
Meteors.2 天前
安卓源码阅读——01.grade设置binding为true时,xml如何进行映射
android·xml
JAVA面经实录9172 天前
MyBatis面试题库
java·mybatis