iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >Mybatis传参类型怎么确定
  • 390
分享到

Mybatis传参类型怎么确定

2023-06-25 10:06:30 390人浏览 薄情痞子
摘要

这篇文章主要介绍mybatis传参类型怎么确定,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!I. 环境配置我们使用SpringBoot + Mybatis + MySql来搭建实例demospringboot: 2.

这篇文章主要介绍mybatis传参类型怎么确定,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

    I. 环境配置

    我们使用SpringBoot + Mybatis + MySql来搭建实例demo

    springboot: 2.2.0.RELEASE
    Mysql: 5.7.22

    1. 项目配置

    <dependencies>    <dependency>        <groupId>org.mybatis.spring.boot</groupId>        <artifactId>mybatis-spring-boot-starter</artifactId>        <version>2.2.0</version>    </dependency>    <dependency>        <groupId>mysql</groupId>        <artifactId>mysql-connector-java</artifactId>    </dependency></dependencies>

    核心的依赖mybatis-spring-boot-starter,至于版本选择,到mvn仓库中,找最新的
    另外一个不可获取的就是db配置信息,appliaction.yml

    spring:  datasource:    url: jdbc:mysql://127.0.0.1:3306/story?useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=Asia/Shanghai    username: root    passWord:

    2. 数据库

    用于测试数据库

    CREATE TABLE `money` (  `id` int(11) unsigned NOT NULL AUTO_INCREMENT,  `name` varchar(20) NOT NULL DEFAULT '' COMMENT '用户名',  `money` int(26) NOT NULL DEFAULT '0' COMMENT '钱',  `is_deleted` tinyint(1) NOT NULL DEFAULT '0',  `create_at` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',  `update_at` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',  PRIMARY KEY (`id`),  KEY `name` (`name`)) ENGINE=InnoDB AUTO_INCREMENT=551 DEFAULT CHARSET=utf8mb4;

    测试数据,主要是name字段,值为一个数字的字符串

    INSERT INTO `money` (`id`, `name`, `money`, `is_deleted`, `create_at`, `update_at`)VALUES (120, '120', 200, 0, '2021-05-24 20:04:39', '2021-09-27 19:21:40');

    II. 传参类型确定

    本文忽略掉mybatis中的po、mapper接口、xml文件的详情,有兴趣的小伙伴可以直接查看最下面的源码(或者查看之前的博文也可以)

    1. 参数类型为整形

    针对上面的case,定义一个根据name查询数据的接口,但是这个name参数类型为整数
    mapper接口:

    List<MoneyPo> queryByName(@Param("name") Integer name);

    对应的xml文件如下

    <select id="queryByName" resultMap="BaseResultMap">    select * from money where `name` = #{name}</select>

    上面这个写法非常常见了,我们现在的问题就是,传参为整数,那么最终的sql是 name = 120 还是 name = '120'呢?
    那么怎么确定最终生成的sql是啥样的呢?这里介绍一个直接输出mysql执行sql日志的方式
    在mysql服务器上执行下面两个命令,开启sql执行日志

    set global general_log = "ON";show variables like 'general_log%';

    当我们访问上面的接口之后,会发现最终发送给mysql的sql语句中,参数替换之后依然是整数

    select * from money where `name` = 120

    2. 指定jdbcType

    在使用#{}, ${}时,有时也会看到除了参数之外,还会指定jdbcType,那么我们在xml中指定这个对最终的sql生成会有影响么?

    <select id="queryByNameV2" resultMap="BaseResultMap">    select * from money where `name` = #{name, jdbcType=VARCHAR} and 0=0</select>

    生成的sql如下

    select * from money where `name` = 120 and 0=0

    从实际的sql来看,这个jdbcType并没有影响最终的sql参数拼接,那它主要是干嘛用呢?(它主要适用于传入null时,类型转换可能出现的异常)

    3. 传参类型为String

    当我们传参类型为string时,最终的sql讲道理应该会带上引号

    List<MoneyPo> queryByNameV3(@Param("name") String name);

    对应的xml

    <select id="queryByNameV3" resultMap="BaseResultMap">    select * from money where `name` = #{name, jdbcType=VARCHAR} and 1=1</select>

    上面这个最终生成的sql如下
    select * from money where `name` = '120' and 1=1

    4. TypeHandler实现参数替换强制添加引号

    看完上面几节,基本上可以有一个得出一个简单的推论(当然对不对则需要从源码上分析了)

    sql参数替换,最终并不是简单使用字符串来替换,实际上是由参数java的参数类型决定,若java参数类型为字符串,拼接的sql为字符串格式;传参为整型,拼接的sql也是整数

    那么问题来了,为什么要了解这个?

    关键点在于索引失效的问题

    比如本文实例中的name上添加了索引,当我们的sql是 select * from money where name = 120 会走不了索引,如果想走索引,要求传入的参数必须是字符串,不能出现隐式的类型转换

    基于此,我们就有一个应用场景了,为了避免由于传参类型问题,导致走不了索引,我们希望name的传参,不管实际传入参数类型是什么,最终拼接的sql,都是字符串的格式;

    我们借助自定义的TypeHandler来实现这个场景

    @MappedTypes(value = {Long.class, Integer.class})@MappedJdbcTypes(value = {JdbcType.CHAR, JdbcType.VARCHAR, JdbcType.LONGVARCHAR})public class StrTypeHandler extends BaseTypeHandler<Object> {        @Override    public void setNonNullParameter(PreparedStatement ps, int i, Object parameter, JdbcType jdbcType) throws SQLException {        ps.setString(i, String.valueOf(parameter));    }        @Override    public Object getNullableResult(ResultSet rs, String columnName) throws SQLException {        return rs.getString(columnName);    }    @Override    public Object getNullableResult(ResultSet rs, int columnIndex) throws SQLException {        return rs.getString(columnIndex);    }    @Override    public Object getNullableResult(CallableStatement cs, int columnIndex) throws SQLException {        return cs.getString(columnIndex);    }}

    然后在xml中,指定TypeHandler

    List<MoneyPo> queryByNameV4(@Param("name") Integer name);
    <select id="queryByNameV4" resultMap="BaseResultMap">    select * from money where `name` = #{name, jdbcType=VARCHAR, typeHandler=com.git.hui.boot.mybatis.handler.StrTypeHandler} and 2=2</select>

    上面这种写法输出的sql就会携带上单引号,这样就可以从源头上解决传参类型不对,导致最终走不了索引的问题

    select * from money where `name` = '120' and 2=2

    以上是“Mybatis传参类型怎么确定”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注编程网精选频道!

    --结束END--

    本文标题: Mybatis传参类型怎么确定

    本文链接: https://www.lsjlt.com/news/304120.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    本篇文章演示代码以及资料文档资料下载

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档
    猜你喜欢
    • Mybatis传参类型怎么确定
      这篇文章主要介绍Mybatis传参类型怎么确定,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!I. 环境配置我们使用SpringBoot + Mybatis + MySql来搭建实例demospringboot: 2....
      99+
      2023-06-25
    • 浅谈Mybatis传参类型如何确定
      目录I.环境配置1.项目配置2.数据库表II.传参类型确定1.参数类型为整形2.指定jdbcType3.传参类型为String4.TypeHandler实现参数替换强制添加引号5.小...
      99+
      2024-04-02
    • Mybatis怎么传入实体类型和基本类型参数
      今天小编给大家分享一下Mybatis怎么传入实体类型和基本类型参数的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。Mybati...
      99+
      2023-07-02
    • mybatis中怎么传递单个String类型的参数
      本篇内容主要讲解“mybatis中怎么传递单个String类型的参数”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“mybatis中怎么传递单个String类型的参数”吧!如何传递单个String...
      99+
      2023-06-21
    • Mybatis怎么传递多个不同类型的参数
      这篇文章主要介绍了Mybatis怎么传递多个不同类型的参数的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Mybatis怎么传递多个不同类型的参数文章都会有所收获,下面我们一起来看看吧。Mybatis传递多个不同...
      99+
      2023-07-05
    • 基于MyBatis的parameterType传入参数类型
      目录MyBatis的parameterType传入参数类型1. MyBatis的传入参数parameterType类型分两种2. 如何获取参数中的值3.案例mybatis 之para...
      99+
      2024-04-02
    • 如何确定 PHP 函数参数的类型
      php 语言中可通过下列方法确定函数参数类型:is_ 函数:使用 is_ 函数检查变量类型,如 is_int() 和 is_array()。类型提示:在函数参数中指定期望类型,使用 : ...
      99+
      2024-04-19
      php 函数参数类型
    • Mybatis如何传入多个参数(实体类型和基本类型)
      目录Mybatis传入多个参数1.ProjectController类2.ProjectAndUserService接口3.ProjectAndUserServiceImpl实现类4...
      99+
      2024-04-02
    • python如何设定函数传参类型
      在python中设定函数传参类型的方法关键字参数关键字参数和函数调用关系紧密,函数调用使用关键字参数来确定传入的参数值。def fun(name, age):print(name + '今年{}了'.format(age))fun(age=...
      99+
      2024-04-02
    • Java中参数传递类型的定义
      本篇内容介绍了“Java中参数传递类型的定义”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!首先看定义:值传递,是指方法接收的是调用者提供的值...
      99+
      2023-06-17
    • mybatis中如何传递单个String类型的参数
      目录如何传递单个String类型的参数mybatis仅传入一个String类型参数报错  目前我知道有两种方式解决问题如何传递单个String类型的参数 使用mybatis接口参数只...
      99+
      2024-04-02
    • MyBatis几种不同类型传参的方式总结
      目录MyBatis几种不同类型传参方式1.String类型2.对于传入Map参数类型3.传入的参数类型为list4.传入对象总结MyBatis几种不同类型传参方式 在Web开发过程中...
      99+
      2022-12-22
      MyBatis传参 MyBatis传参方式 MyBatis不同类型传参
    • Mybatis(ParameterType)传递多个不同类型的参数方式
      目录Mybatis传递多个不同类型的参数基于注解Mybatis传递单个String类型的参数总结Mybatis传递多个不同类型的参数 在一些场景下,传参是需要多个参数的。一个参数不太...
      99+
      2023-05-14
      Mybatis ParameterType Mybatis传递不同类型参数 Mybatis传递参数
    • mybatis对传入基本类型参数的判断方式
      目录对传入基本类型参数的判断解决办法传入基本类型参数时test判断报错分析解决办法小结一下对传入基本类型参数的判断 mybatis的xml文件的sql语句中parameterType...
      99+
      2024-04-02
    • C#中ParameterDirection参数类型怎么定义
      在C#中,可以使用System.Data.ParameterDirection枚举定义ParameterDirection参数类型。...
      99+
      2023-09-26
      C#
    • Mybatis-Plus怎么自定义集合类型的类型处理器
      这篇文章主要讲解了“Mybatis-Plus怎么自定义集合类型的类型处理器”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Mybatis-Plus怎么自定义集合类型的类型处理器”吧!1.配合x...
      99+
      2023-06-26
    • mybatis foreach怎么传两个参数
      这篇文章主要介绍了mybatis foreach怎么传两个参数的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇mybatis foreach怎么传两个参数文章都会有所收获,下面我们一起来看看吧...
      99+
      2023-07-06
    • js怎么传各种类型参数到Controller层
      这篇文章主要讲解了“js怎么传各种类型参数到Controller层”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“js怎么传各种类型参数到Controller层”吧!一 .@RequestBo...
      99+
      2023-07-05
    • Golang怎么实现函数任意类型传参
      这篇文章将为大家详细讲解有关Golang怎么实现函数任意类型传参,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。golang适合做什么golang可以做服务器端开发,但golang很适合做日志处理、数据打包...
      99+
      2023-06-14
    • SpringMVC五种类型参数传递及json传递参数
      目录案例分析:1.pom.xml2.ServletContainersInitConfig3.SpringMvcConfig4.UserController5.Address6.Us...
      99+
      2024-04-02
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作