第十章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);

相关推荐
帅到爆的努力小陈5 分钟前
Java集合框架中List常见问题
java·集合·list集合·java-list
肥or胖18 分钟前
【FFmpeg 快速入门】本地播放器 项目
开发语言·qt·ffmpeg·音视频
inwith1 小时前
C#语法基础总结(超级全面)(二)
开发语言·c#
_pengliang1 小时前
小程序按住说话
开发语言·javascript·小程序
秋千码途1 小时前
小架构step系列17:getter-setter-toString
java·开发语言·架构
吃西瓜不吐籽_2 小时前
Mac 安装及使用sdkman指南
java·笔记
晨启AI2 小时前
Trae IDE:打造完美Java开发环境的实战指南
java·环境搭建·trae
C雨后彩虹2 小时前
行为模式-策略模式
java·设计模式·策略模式
Ashlee_code2 小时前
美联储降息趋缓叠加能源需求下调,泰国证券交易所新一代交易系统架构方案——高合规、强韧性、本地化的跨境金融基础设施解决方案
java·算法·金融·架构·系统架构·区块链·需求分析
AI 嗯啦2 小时前
python基础语法9,用os库实现系统操作并用sys库实现文件操作(简单易上手的python语法教学)
开发语言·python