第十章MyBatis的参数

单个简单参数处理

MyBatis中的sql语句中的属性

  • id:为mapper接口的方法名
  • resultType:为返回参数的类型
  • parameterType:为传递过来的参数类型,MyBatis会自动推断一般不用填写

javaType表示说明这个字段的java类型

jdbcType表示说明这个字段在数据库中的类型

复制代码
<select>
	select * from car where name=#{name,javaType=String,jdbcType=VARCHAR}
</select>

javaType和jdbcType,parameterType这些MyBatis都会自动推断类型,一般不用写


Map参数处理

  • map数据类型,sql中的#{}为map类型的key
  • Map类型也可以被自动推断类型

Pojo参数处理

  • Pojo数据类型,sql中的#{}为属性名通过调用get方法获取值
  • Pojo类型也可以被自动推断类型,返回类型也会被自动推断

多个参数

  • 如果是多个参数不用写参数类型(parameterType)

  • MyBatis如果接受到的是多个参数,会自动创建一个map集合("arg0/param1","value")...存放

    // 获取方式一
    <select id="selectById" resultType="com.example.webapplication.pojo.Car">
    select
    *
    from car
    limit #{arg0},#{arg1};
    </select>

    // 获取方式二
    <select id="selectById" resultType="com.example.webapplication.pojo.Car">
    select
    *
    from car
    limit #{param1},#{param2};
    </select>
    ...

  • 通过在接口上@Param(value="参数名")来指定参数名,就不能用arg0但是param1可以使用

    List<Car> slect(@Param(value = "page") Integer page,@Param(value="limit") Integer limit);

相关推荐
码畜也有梦想2 分钟前
Maven中optional的作用
java·jenkins·maven
云和数据.ChenGuang21 分钟前
java常见SSL bug解决方案
java·bug·ssl
songx_9924 分钟前
leetcode29( 有效的括号)
java·数据结构·算法·leetcode
于樱花森上飞舞29 分钟前
【java】常见排序算法详解
java·算法·排序算法
维持好习惯32 分钟前
复杂Excel文件导入功能(使用AI快速实现)
java·spring boot·excel
酷炫码神39 分钟前
第 2 篇:Java 入门实战(JDK8 版)—— 编写第一个 Java 程序,理解基础运行逻辑
java·开发语言·策略模式
像风一样自由202041 分钟前
Go语言详细指南:特点、应用场景与开发工具
开发语言·后端·golang
半夏知半秋43 分钟前
基于跳跃表的zset实现解析(lua版)
服务器·开发语言·redis·学习·lua
月阳羊1 小时前
【硬件-笔试面试题-93】硬件/电子工程师,笔试面试题(知识点:波特图)
java·经验分享·单片机·嵌入式硬件·面试
Wyc724091 小时前
Lua语言基础笔记
开发语言·笔记·lua