在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>
相关推荐
空空kkk17 小时前
MyBatis——代理Dao方式的增删改查操作
java·数据库·mybatis
小小测试开发1 天前
JMeter XPath2 Extractor用法全解析:精准提取XML/HTML响应数据
xml·jmeter·html
likuolei1 天前
XML 元素 vs. 属性
xml·java·开发语言
2501_941800882 天前
Java高性能搜索引擎与Lucene实战分享:大规模文本索引、检索与优化经验
mybatis
q***42822 天前
SpringCloud-持久层框架MyBatis Plus的使用与原理详解
spring·spring cloud·mybatis
北郭guo2 天前
MyBatis框架讲解,工作原理、核心内容、如何实现【从浅入深】让你看完这篇文档对于MyBatis的理解更加深入
java·数据库·mybatis
likuolei2 天前
XML DOM - NodeList 对象
xml
q***16083 天前
Tomcat的server.xml配置详解
xml·java·tomcat
百***81273 天前
使用 Logback 的最佳实践:`logback.xml` 与 `logback-spring.xml` 的区别与用法
xml·spring·logback
小小测试开发3 天前
JMeter XPath提取器用法详解:XML/HTML响应数据提取神器
xml·jmeter·html