我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Mybatis传参类型怎么确定

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Mybatis传参类型怎么确定

这篇文章主要介绍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传参类型怎么确定”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注编程网行业资讯频道!

    免责声明:

    ① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

    ② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

    Mybatis传参类型怎么确定

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

    下载Word文档

    猜你喜欢

    Mybatis传参类型怎么确定

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

    Mybatis怎么传入实体类型和基本类型参数

    今天小编给大家分享一下Mybatis怎么传入实体类型和基本类型参数的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。Mybati
    2023-07-02

    mybatis中怎么传递单个String类型的参数

    本篇内容主要讲解“mybatis中怎么传递单个String类型的参数”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“mybatis中怎么传递单个String类型的参数”吧!如何传递单个String
    2023-06-21

    Mybatis怎么传递多个不同类型的参数

    这篇文章主要介绍了Mybatis怎么传递多个不同类型的参数的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Mybatis怎么传递多个不同类型的参数文章都会有所收获,下面我们一起来看看吧。Mybatis传递多个不同
    2023-07-05

    如何确定 PHP 函数参数的类型

    php 语言中可通过下列方法确定函数参数类型:is_ 函数:使用 is_ 函数检查变量类型,如 is_int() 和 is_array()。类型提示:在函数参数中指定期望类型,使用 : 语法,如 function calculate_to
    如何确定 PHP 函数参数的类型
    2024-04-19

    Java中参数传递类型的定义

    本篇内容介绍了“Java中参数传递类型的定义”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!首先看定义:值传递,是指方法接收的是调用者提供的值
    2023-06-17

    MyBatis几种不同类型传参的方式总结

    这篇文章主要介绍了MyBatis几种不同类型传参的方式总结,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-12-22

    Mybatis(ParameterType)传递多个不同类型的参数方式

    这篇文章主要介绍了Mybatis(ParameterType)传递多个不同类型的参数方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-05-14

    Mybatis-Plus怎么自定义集合类型的类型处理器

    这篇文章主要讲解了“Mybatis-Plus怎么自定义集合类型的类型处理器”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Mybatis-Plus怎么自定义集合类型的类型处理器”吧!1.配合x
    2023-06-26

    C#中ParameterDirection参数类型怎么定义

    在C#中,可以使用System.Data.ParameterDirection枚举定义ParameterDirection参数类型。这个枚举包含以下值:1. Input:指定参数是一个输入参数。2. Output:指定参数是一个输出参数。3
    2023-09-26

    mybatis foreach怎么传两个参数

    这篇文章主要介绍了mybatis foreach怎么传两个参数的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇mybatis foreach怎么传两个参数文章都会有所收获,下面我们一起来看看吧。需求foreach
    2023-07-06

    Golang怎么实现函数任意类型传参

    这篇文章将为大家详细讲解有关Golang怎么实现函数任意类型传参,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。golang适合做什么golang可以做服务器端开发,但golang很适合做日志处理、数据打包
    2023-06-14

    js怎么传各种类型参数到Controller层

    这篇文章主要讲解了“js怎么传各种类型参数到Controller层”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“js怎么传各种类型参数到Controller层”吧!一 .@RequestBo
    2023-07-05

    Springcloud feign传日期类型参数报错怎么办

    这篇文章给大家分享的是有关Springcloud feign传日期类型参数报错怎么办的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。feign传日期类型参数报错Date类型参数报错在Spring cloud fei
    2023-06-29

    编程热搜

    • Python 学习之路 - Python
      一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
      Python 学习之路 - Python
    • chatgpt的中文全称是什么
      chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
      chatgpt的中文全称是什么
    • C/C++中extern函数使用详解
    • C/C++可变参数的使用
      可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
      C/C++可变参数的使用
    • css样式文件该放在哪里
    • php中数组下标必须是连续的吗
    • Python 3 教程
      Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
      Python 3 教程
    • Python pip包管理
      一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
      Python pip包管理
    • ubuntu如何重新编译内核
    • 改善Java代码之慎用java动态编译

    目录