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

MyBatis中的占位符入参方法有哪些

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

北京

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

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

看不清楚,换张图片

免费获取短信验证码

MyBatis中的占位符入参方法有哪些

本篇内容主要讲解“MyBatis中的占位符入参方法有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MyBatis中的占位符入参方法有哪些”吧!

    前言

    #{}占位符会被解析为JDBC中的预编译语句(Prepared Statement)中的参数占位符?,一个#{}会被解析为一个?

    ${}占位符标识的位置会直接被替换为入参,是简单的字符串替换。

    正文

    一. 入参是基本类型并且参数个数为1

    映射接口中查询单条记录的方法定义如下。

    // 使用#{}作为参数占位符MyInfo getMyInfoByNameUseWell(String infoName);// 使用${}作为参数占位符MyInfo getMyInfoByNameUseDollar(String infoName);

    与之对应的映射文件中的查询标签定义如下。

    <select id="getMyInfoByNameUseWell" resultMap="myInfoMap">    SELECT * FROM myinfo WHERE info_name = #{name}</select><select id="getMyInfoByNameUseDollar" resultMap="myInfoMap">    SELECT * FROM myinfo WHERE info_name = '${name}'</select>

    入参是基本类型(示例中是String类型)且参数个数只有一个时,使用#{}${}占位符均不要求占位符指定的名称与映射接口中的参数名相等,但是#{}进行占位符替换后参数会添加上''号,而${}进行占位符替换是直接进行字符串替换,所以上述示例中,使用${}占位符时需要在占位符两侧添加''号。

    二. 入参是基本类型并且参数个数大于1

    映射接口中查询单条记录的方法定义如下。

    // 使用#{}作为参数占位符MyInfo getMyInfoByNameTypeUseWell(@Param("infoName") String infoName, @Param("infoType") String infoType);// 使用${}作为参数占位符MyInfo getMyInfoByNameTypeUseDollar(@Param("infoName") String infoName, @Param("infoType") String infoType);

    与之对应的映射文件中的查询标签定义如下。

    <select id="getMyInfoByNameTypeUseWell" resultMap="myInfoMap">    SELECT * FROM myinfo WHERE info_name = #{infoName} AND info_type = #{infoType}</select><select id="getMyInfoByNameTypeUseDollar" resultMap="myInfoMap">    SELECT * FROM myinfo WHERE info_name = '${infoName}' AND info_type = '${infoType}'</select>

    入参是基本类型且参数个数大于一个时,此时需要在映射接口的方法中使用@Param注解定义参数的名称,并且要求占位符指定的名称需要与@Param注解定义的名称相等,否则报错

    三. 入参是自定义类型

    映射接口中查询单条记录的方法定义如下。

    // 使用#{}作为参数占位符MyInfo getMyInfoByQueryParamUseWell(QueryParam queryParam);// 使用${}作为参数占位符MyInfo getMyInfoByQueryParamUseDollar(QueryParam queryParam);

    其中自定义类型QueryParam定义如下。

    @Datapublic class QueryParam {    private String infoName;    private String infoType;    public QueryParam(String infoName, String infoType) {        this.infoName = infoName;        this.infoType = infoType;    }}

    与之对应的映射文件中的查询标签定义如下。

    <select id="getMyInfoByQueryParamUseWell" resultMap="myInfoMap"        parameterType="com.learn.mybatis.dynamic.entity.QueryParam">    SELECT * FROM myinfo WHERE info_name = #{infoName} AND info_type = #{infoType}</select><select id="getMyInfoByQueryParamUseDollar" resultMap="myInfoMap"        parameterType="com.learn.mybatis.dynamic.entity.QueryParam">    SELECT * FROM myinfo WHERE info_name = '${infoName}' AND info_type = '${infoType}'</select>

    入参是自定义类型时,占位符指定的名称需要与自定义类型中的字段名相同,否则报错

    四. 入参是Map类型

    映射接口中查询单条记录的方法定义如下。

    // 使用#{}作为参数占位符MyInfo getMyInfoByMapUseWell(Map<String, Object> queryParamMap);// 使用${}作为参数占位符MyInfo getMyInfoByMapUseDollar(Map<String, Object> queryParamMap);

    与之对应的映射文件中的查询标签定义如下。

    <select id="getMyInfoByMapUseWell" resultMap="myInfoMap">    SELECT * FROM myinfo WHERE info_name = #{infoName} AND info_type = #{infoType}</select><select id="getMyInfoByMapUseDollar" resultMap="myInfoMap">    SELECT * FROM myinfo WHERE info_name = '${infoName}' AND info_type = '${infoType}'</select>

    入参是Map时,占位符指定的名称需要与Map的key相等,这样才能将key对应的value与占位符进行替换

    五. 只能使用${}的场景

    通过上面几点分析,发现大多数能够使用${}占位符的场景都可以使用#{}占位符,而且#{}占位符相比${}占位符还具有能够防止SQL注入提高执行速度的功能,但是如下几种场景,只能够使用${}占位符。

    1. 入参是表名

    当入参是表名时,此时如果表名的参数占位符使用#{},会报错,因为表名不确定时,是无法进行预编译SQL的,所以这种场景只能使用${}作为表名的参数占位符。下面是示例。

    映射接口中的示例方法定义如下。

    // 传入表名实现动态创建表void createMyInfoTable(String tableName);// 传入表名动态指定被查询的表MyInfo getMyInfoByNameUseWellDynmic(@Param("tableName") String tableName, @Param("infoName") String infoName);

    与之对应的映射文件中的标签定义如下。

    <update id="createMyInfoTable">    CREATE TABLE ${tableName} (        id INT(11) PRIMARY KEY AUTO_INCREMENT,        info_name VARCHAR(255),        info_type ENUM('USER', 'HOUSE', 'CAR'),        info_detail VARCHAR(255),        info_seq INT(11)    )</update><select id="getMyInfoByNameUseWellDynmic" resultMap="myInfoMap">    SELECT * FROM ${tableName} WHERE info_name = #{infoName}</select>
    2. 入参是列名

    当入参是列名时,此时也只能使用${}作为列名的参数占位符。下面是示例。

    映射接口中的方法定义如下。

    // 为数据库表创建索引// 表名,索引名,加索引的列的列名全部动态指定void createIndex(@Param("tableName") String tableName,                  @Param("indexName") String indexName,                  @Param("columnNames") List&lt;String&gt; columnNames);// 对查询结果集进行排序并动态指定排序的列名List&lt;MyInfo&gt; getMyInfosSorted(String columnName);

    与之对应的映射文件中的标签定义如下。

    <update id="createIndex">    CREATE INDEX        ${indexName}    ON        ${tableName}    <foreach collection="columnNames" item="columnName"                open="(" separator="," close=")">        ${columnName}    </foreach></update><select id="getMyInfosSorted" resultMap="myInfoMap">    SELECT * FROM myinfo ORDER BY ${columnName} DESC</select>

    在为数据库表创建索引的示例中,表名,索引名和加索引的列的列名全部都需要使用${}作为参数占位符,否则会报错。在对查询结果集进行排序的示例中,如果列名占位符不使用${}而使用#{},不会报错,但是无法实现根据指定列进行排序的功能。

    到此,相信大家对“MyBatis中的占位符入参方法有哪些”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

    免责声明:

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

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

    MyBatis中的占位符入参方法有哪些

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

    下载Word文档

    猜你喜欢

    MyBatis中的占位符入参方法有哪些

    本篇内容主要讲解“MyBatis中的占位符入参方法有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MyBatis中的占位符入参方法有哪些”吧!前言#{}占位符会被解析为JDBC中的预编译语句
    2023-07-05

    MyBatis中的占位符入参全面详解

    这篇文章主要为大家介绍了MyBatis中的占位符全面详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-03-01

    python常见的占位符有哪些

    这篇文章将为大家详细讲解有关python常见的占位符有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。占位符说明1、%c,格式化字符及其ASCII码2、%s,格式化字符串3、%d,格式化整数4、%u,格
    2023-06-20

    nacos使用占位符${}进行参数配置的方法

    这篇文章主要介绍了nacos如何使用占位符${}进行参数配置,本文结合示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-12-26

    java泛型中占位符T和?有哪些区别

    这篇文章主要讲解了“java泛型中占位符T和?有哪些区别”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“java泛型中占位符T和?有哪些区别”吧!先上两段代码:public static
    2023-06-30

    python传入参数的方法有哪些

    在Python中,传递参数的方法有以下几种:1. 位置参数(Positional Arguments):按照参数在函数定义时的顺序进行传递,可以根据参数的位置来确定参数的值。示例:```pythondef greet(name, age):
    2023-09-16

    JS位运算符的使用方法有哪些

    本篇内容主要讲解“JS位运算符的使用方法有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“JS位运算符的使用方法有哪些”吧!1. 使用左移运算符 << 迅速得出2的次方1 << 2 // 4
    2023-06-29

    向php传入参数的方法有哪些

    这篇文章主要讲解了“向php传入参数的方法有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“向php传入参数的方法有哪些”吧!向php传入参数的三种方法:1、使用“$argv”或者“$ar
    2023-06-21

    java中输入一个字符的方法有哪些

    以下将列出几种方法:方法一:从控制台接收一个字符,然后将其打印出来public static void main(String [] args) throws IOException{  System.out.print(“Enter a Char:”);  
    java中输入一个字符的方法有哪些
    2018-10-18

    Java中Mybatis分页查询的传参方式有哪些

    这篇文章主要介绍了Java中Mybatis分页查询的传参方式有哪些的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Java中Mybatis分页查询的传参方式有哪些文章都会有所收获,下面我们一起来看看吧。一、顺序传
    2023-07-05

    java中invoke方法的参数有哪些

    在Java中,invoke方法的参数有以下几种:1. 调用的对象(或者类):可以是一个实例对象或者一个类对象。2. 方法名:要调用的方法的名称。3. 方法的参数类型:指定方法的参数类型,如果方法有多个参数,则可以提供多个参数类型。4. 方法
    2023-08-08

    Golang中的位操作方法有哪些

    这篇文章主要讲解了“Golang中的位操作方法有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Golang中的位操作方法有哪些”吧!在计算机内存昂贵,处理能力有限的美好旧时光里,用比较黑
    2023-07-05

    mybatis分页的方法有哪些

    这篇文章主要讲解了“mybatis分页的方法有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mybatis分页的方法有哪些”吧!mybatis分页的3种方式是:1、使用Limit分页,其
    2023-07-05

    mybatis对传入基本类型参数的判断方式有哪些

    这篇文章主要介绍mybatis对传入基本类型参数的判断方式有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!对传入基本类型参数的判断mybatis的xml文件的sql语句中parameterType为基本类型,如:
    2023-06-29

    css中元素的定位方法有哪些

    css 中,元素定位方法共有五种,包括:静态定位:默认定位,元素在页面中占据正常流位置。相对定位:相对于元素当前位置定位,脱离文档流但不影响其他元素。绝对定位:相对于包含元素定位,脱离文档流,影响其他元素。固定定位:相对于视口定位,不影响其
    css中元素的定位方法有哪些
    2024-04-26

    Mybatis批量插入大量数据的方法有哪些

    本文小编为大家详细介绍“Mybatis批量插入大量数据的方法有哪些”,内容详细,步骤清晰,细节处理妥当,希望这篇“Mybatis批量插入大量数据的方法有哪些”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。Mybat
    2023-07-05

    SpringBoot中参数校验的方法有哪些

    这篇文章给大家分享的是有关SpringBoot中参数校验的方法有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一、前言在 Web 开发中经常需要对前端传过来的参数进行校验,例如格式校验、非空校验等,基本上每个
    2023-06-15

    编程热搜

    • 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动态编译

    目录