`
zzc1684
  • 浏览: 1230989 次
  • 性别: Icon_minigender_1
  • 来自: 广州
文章分类
社区版块
存档分类
最新评论

MyBatis传入参数与parameterType

阅读更多

MyBatis传入参数与parameterType

December 25, 2013DatabaseJavaopenwares

MybatisMapper文件中的selectinsertupdatedelete元素中有一个parameterType属性,用于对应的mapper接口方法接受的参数类型。

可以接受的参数类型有基本类型和复杂类型。

mapper接口方法一般接受一个参数,可以通过使用@Param注释将多个参数绑定到一个map做为输入参数。

1.     简单数据类型

mapper接口方法:

1

User selectByPrimaryKey(Integer id);

sql映射:

1

2

3

4

5

6

<selectid="selectByPrimaryKey"resultMap="BaseResultMap"parameterType="java.lang.Integer">

select

<includerefid="Base_Column_List"/>

from base.tb_user

where id = #{id,jdbcType=INTEGER}

</select>

对于简单数据类型,sql映射语句中直接#{变量名}这种方式引用就行了,其实这里的"变量名"可以是任意的。mapper接口方法传递过来的值,至于其叫什么名字其实是不可考也没必要知道的。
而且JAVA反射只能获取方法参数的类型,是无从得知方法参数的名字的。

比如上面这个示例中,使用#{id}来引用只是比较直观而已,使用其他名字来引用也是一样的。所以当在if元素中test传递的参数时,就必须要用_parameter来引用这个参数了。像这样:

1

2

3

4

5

6

7

8

<selectid="selectByPrimaryKey"resultMap="BaseResultMap"parameterType="java.lang.Integer">

select

<includerefid="Base_Column_List"/>

from tb_user

<iftest="_parameter != 0">

where id = #{id,jdbcType=INTEGER}

</if>

</select>

如果test测试条件中使用id就会提示错误,因为这个参数其实没有名字,只是一个值或引用而已,只能使用_parameter来引用。

2.     对象类型

传入JAVA复杂对象类型的话,sql映射语句中就可以直接引用对象的属性名了,这里的属性名是实实在在的真实的名字,不是随意指定的。
mapper
接口方法:

1

intinsert(User user);

sql映射:

1

2

3

<insertid="insert"parameterType="User"useGeneratedKeys="true"keyProperty="id">

insert into tb_user (name, sex)

values (#{name,jdbcType=CHAR}, #{sex,jdbcType=CHAR})

虽然可以明确的引用对象的属性名了,但如果要在if元素中测试传入的user参数,仍然要使用_parameter来引用传递进来的实际参数,因为传递进来的User对象的名字是不可考的。如果测试对象的属性,则直接引用属性名字就可以了。

测试user对象:

1

<iftest="_parameter != null">

测试user对象的属性:

1

<iftest="name != null">

3.     map类型

传入map类型,直接通过#{keyname}就可以引用到键对应的值。使用@param注释的多个参数值也会组装成一个map数据结构,和直接传递map进来没有区别。

mapper接口:

1

intupdateByExample(@Param("user") User user, @Param("example") UserExample example);

sql映射:

1

2

3

4

5

6

7

<updateid="updateByExample"parameterType="map">

update tb_user

set id = #{user.id,jdbcType=INTEGER},

...

<iftest="_parameter != null">

<includerefid="Update_By_Example_Where_Clause"/>

</if>

注意这里测试传递进来的map是否为空,仍然使用_parameter

4.     集合类型

You can pass a List instance or an Array to MyBatis as a parameter object. When you do, MyBatis will automatically wrap it in a Map, and key it by name. List instances will be keyed to the name "list" and array instances will be keyed to the name "array".

可以传递一个ListArray类型的对象作为参数,MyBatis会自动的将ListArray对象包装到一个Map对象中,List类型对象会使用list作为键名,Array对象会用array作为键名。

集合类型通常用于构造IN条件,sql映射文件中使用foreach元素来遍历ListArray元素。

mapper接口:

1

User selectUserInList(List<Interger> idlist);

sql动态语句映射:

1

2

3

4

5

6

7

8

9

<selectid="selectUserInList"resultType="User">

SELECT *

FROM USER

WHERE ID in

<foreachitem="item"index="index"collection="list"

open="("separator=","close=")">

#{item}

</foreach>

</select>

5.     对象类型中的集合属性

对于单独传递的ListArray,SQL映射文件中映射时,只能通过listarray来引用。但是如果对象类型有属性的类型为ListArray,则在sql映射文件的foreach元素中,可以直接使用属性名字来引用。
mapper
接口:

1

List<User> selectByExample(UserExample example);

sql映射文件:

1

2

3

<where>

<foreachcollection="oredCriteria"item="criteria"separator="or">

<iftest="criteria.valid">

在这里,UserExample有一个属性叫oredCriteria,其类型为List,所以在foreach元素里直接用属性名oredCriteria引用这个List即可。

item="criteria"表示使用criteria这个名字引用每一个集合中的每一个ListArray元素

 

 

 

分享到:
评论

相关推荐

    MyBatis中传入参数parameterType类型详解

    MyBatis中传入参数parameterType类型详解 MyBatis是一款流行的持久层框架,它提供了一个灵活的方式来与数据库交互。在MyBatis中,parameterType类型是Mapper文件中的一个重要属性,它用于指定Mapper接口方法接受的...

    总结--Mybatis传递参数的几种方法

    Mybatis 传递参数的几种方法 Mybatis 中传递参数有多种方法,以下是其中的四种: 1. 传递单个参数 在 Mybatis 中,传递单个参数非常简单。可以直接将参数写在方法中,参数类型可以是 String,也可以是基本类型,...

    MyBatis传入多个参数的问题

    ### MyBatis传入多个参数的问题 在使用MyBatis框架进行数据库操作时,经常会遇到需要向SQL查询语句传入多个参数的情况。本文将详细介绍几种常见的多参数传递方法,并结合具体的代码示例来帮助读者更好地理解和应用...

    Mybatis框架 mapper.xml文件中parameterType传递参数常用的几种方式.pdf

    以下是几种常用的parameterType参数传递方式以及#和$在Mybatis中传参的区别。 1. 使用依次顺序传参: 在这种方式中,参数按照顺序传递,SQL语句中使用#{参数索引}来引用参数。例如,有一个查询用户的方法,用户名...

    MyBatis传入参数的实例代码

    当传入的参数为Java的基本数据类型(如int, String, Date等)时,可以在XML映射文件中通过`parameterType`属性指定参数类型,然后在SQL语句中使用`#{参数名}`来获取传入的值。例如,查询ID为2的教师列表: ```xml...

    关于MyBatis参数传入#{index}的问题的解决方案【源码】

    首先,让我们明确MyBatis中的#{index}与${index}的区别。#{index}是预编译的参数,它会将参数值转化为PreparedStatement的参数,有助于防止SQL注入。而${index}则是在SQL字符串中直接替换变量,不进行预编译,存在...

    MyBatis拦截器分页与动态修改SQL及其参数值

    例如,我们可以在拦截器中检查传入的参数,如果需要模糊查询,可以在SQL语句中添加`LIKE`条件。例如: ```xml &lt;select id="selectUsers" parameterType="map"&gt; SELECT * FROM user != null"&gt; WHERE name LIKE #{...

    mybatis动态插入list传入List参数的实例代码

    MyBatis 动态插入 List 传入 List 参数的实例代码详解 MyBatis 是一款优秀的 ORM 工具,提供了许多实用的功能,其中之一便是动态插入 List,下面我们将通过实例代码详解 MyBatis 动态插入 List 传入 List 参数的...

    mybatis动态sql之Map参数的讲解

    在MyBatis中,我们可以使用两种方式来传递Map参数:方式一是使用parameterType="Map"方式,例如: ```xml &lt;update id="publishT00_notice" parameterType="Map"&gt; update test set createdate = #{createdate}, ...

    MyBatis(四)

    这里的`id`为方法的唯一标识,`parameterType`指定传入参数的类型,`#{id}`是参数占位符,MyBatis会自动将传入的参数值替换到这里。 2. Mapper接口定义:在Java接口中,我们需要定义与XML中`id`对应的删除方法: `...

    Mybatis参数传递1

    这里`parameterType`指定了参数类型,MyBatis会自动将方法参数值绑定到`#{command}`占位符上。 2. 参数封装到对象中 如果需要更复杂的查询条件,可以将参数封装到一个对象中,比如`MessageQuery`类,然后通过对象的...

    MyBatis参数处理.docx

    在MyBatis框架中,参数处理是一个关键环节,它决定了SQL查询语句如何根据传入的参数进行动态构建。本示例中,我们看到了两种不同的参数处理方式:使用Map和JavaBean。 1. **Map参数处理**: - 在映射文件中,`...

    mybatis参数解说

    ### MyBatis参数详解 #### 一、概述 在MyBatis框架中,处理数据库操作时,经常需要向SQL语句传递各种类型的参数。这些参数包括简单数据类型(如Integer、String等)、复杂的对象类型(如自定义JavaBean类)、Map...

    Mybatis使用(上

    这里的`id`是Java方法名,`parameterType`是传入参数的类型,`#{}`用于占位符,Mybatis会自动处理参数替换。 五、Eclipse中运行Mybatis 1. 创建Java项目,导入Mybatis的jar包,包括mybatis-x.x.x.jar、mybatis-...

    mybatis 报空值异常

    当 MyBatis 在执行 SQL 语句时,如果参数是 `null` 而没有明确指定对应的 JDBC 类型,那么就会抛出类似于以下的异常: ``` Error setting null for parameter #1 with JdbcType OTHER. Try setting a different ...

    MyBatis3DTD约束

    5. **parameterMap**:虽然在MyBatis3中已不再推荐使用,但在旧版本或复杂场景下,它用于定义参数集合,通过name属性与传入的参数对象关联。 6. **sql**:这是一个可重用的SQL片段,可以通过include元素在其他地方...

    springmybatis

    mybatis实战教程mybatis in action之五与spring3集成附源码 mybatis实战教程mybatis in action之六与Spring MVC 的集成 mybatis实战教程mybatis in action之七实现mybatis分页源码下载 mybatis实战教程mybatis in ...

    mybatis调用存储过程

    (2)在 `&lt;select&gt;` 标签内,使用 `{call}` 关键字并传入存储过程的完整名称,包括所有必要的参数。参数应以问号(?)表示,并按照参数顺序排列。 (3)在Java代码中,创建一个Map对象,用于传递存储过程的输入/...

    Mybatis排序无效问题解决.doc

    1. **预编译与安全防护**:在Mybatis中,`#{}`主要用于参数预编译,它可以有效防止SQL注入攻击。预编译过程中,`#{}`内的表达式被视为参数值而非SQL的一部分,因此会被转换为字符串形式,再通过占位符(如`?`)进行...

    MyBatis调用存储过程

    `是参数占位符,MyBatis会自动替换为传入的参数值。 ### 2. 参数传递 MyBatis支持两种方式传递参数:Map和POJO(Plain Old Java Object)。对于存储过程,我们通常使用Map,因为存储过程可能有多个输入/输出参数。...

Global site tag (gtag.js) - Google Analytics