mysql parametertype 传model怎么获取
1个回答
展开全部
简单数据类型
mapper接口方法:
1
User
selectByPrimaryKey(Integer id);
sql映射:
1
2
3
4
5
6
<select
id="selectByPrimaryKey"
resultMap="BaseResultMap"
parameterType="java.lang.Integer"
>
select
<include
refid="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
<select
id="selectByPrimaryKey"
resultMap="BaseResultMap"
parameterType="java.lang.Integer"
>
select
<include
refid="Base_Column_List"
/>
from
tb_user
mapper接口方法:
1
User
selectByPrimaryKey(Integer id);
sql映射:
1
2
3
4
5
6
<select
id="selectByPrimaryKey"
resultMap="BaseResultMap"
parameterType="java.lang.Integer"
>
select
<include
refid="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
<select
id="selectByPrimaryKey"
resultMap="BaseResultMap"
parameterType="java.lang.Integer"
>
select
<include
refid="Base_Column_List"
/>
from
tb_user
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询
广告 您可能关注的内容 |