在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>
相关推荐
哆啦A梦15882 小时前
Springboot整合MyBatis实现数据库操作
数据库·spring boot·mybatis
弹简特10 小时前
【JavaEE19-后端部分】 MyBatis 入门第三篇:使用XML完成增删改查
xml·mybatis
小江的记录本15 小时前
【VO、DTO、Entity】VO、DTO、Entity三大核心数据对象全解析(附核心对比表 + 代码示例)
java·数据库·spring boot·spring·架构·mybatis·数据库架构
计算机学姐15 小时前
基于SpringBoot的流浪动物救助收养系统
vue.js·spring boot·后端·mysql·java-ee·intellij-idea·mybatis
spencer_tseng16 小时前
Tomcat server.xml <Connector> address=“0.0.0.0“
xml·tomcat
计算机学姐17 小时前
基于SpringBoot的蛋糕烘焙销售服务系统
java·spring boot·后端·spring·tomcat·intellij-idea·mybatis
zdl68617 小时前
Mybatis控制台打印SQL执行信息(执行方法、执行SQL、执行时间)
数据库·sql·mybatis
敲代码的嘎仔1 天前
Java后端面试——SSM框架面试题
java·面试·职场和发展·mybatis·ssm·springboot·八股
ruanyongjing1 天前
SpringBoot3 整合 Mybatis 完整版
mybatis
小江的记录本1 天前
【MyBatis-Plus】Spring Boot + MyBatis-Plus 进行各种数据库操作(附完整 CRUD 项目代码示例)
java·前端·数据库·spring boot·后端·sql·mybatis