在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>
相关推荐
LiZhen7981 天前
SpringBoot 实现动态切换数据源
java·spring boot·mybatis
我是Superman丶1 天前
在 PostgreSQL 中使用 JSONB 类型并结合 MyBatis-Plus 实现自动注入,主要有以下几种方案
数据库·postgresql·mybatis
Pluto_CSND1 天前
基于mybatis-generator插件生成指定数据表的实体类、xml文件和dao层接口
mybatis
indexsunny1 天前
互联网大厂Java面试实战:微服务与Spring生态技术解析
java·spring boot·redis·kafka·mybatis·hibernate·microservices
手握风云-1 天前
JavaEE 进阶第十六期:MyBatis,查询请求的生命周期全景图(一)
java·java-ee·mybatis
独断万古他化1 天前
【SSM开发实战:博客系统】(二)JWT 登录流程、拦截器实现和用户信息接口落地
spring boot·spring·mybatis·博客系统·项目
Pluto_CSND1 天前
MyBatis 的 XML 文件中特殊字符的处理
mybatis
独断万古他化1 天前
【SSM开发实战:博客系统】(一)项目初始化与基础功能实现
spring boot·spring·mybatis·博客系统·项目
tb_first2 天前
万字超详细苍穹外卖学习笔记4
java·spring boot·笔记·学习·spring·mybatis
2301_818732062 天前
项目启动报错,错误指向xml 已解决
xml·java·数据库·后端·springboot