#{ }和${ } 、参数处理

news2025/1/22 19:11:57

目录

#{ }和${ } 

参数处理

入参-parameterType

使用Map

使用Bean / List<Bean>

使用多参数 

@Param注解(命名参数)

出参-resultType 

返回Map / List<Map>

返回Map<String,Map>

属性名不一致-resultMap结果映射


#{ }和${ } 

如果查找 carType=#{carType},carType=${carType}

        #{}:底层是PreparedStatement实现,会先编译再拼接。

                变成:type =' ',再把值传进去,即 type=' 燃油车 '。

        ${}:底层是Statement实现,会先拼接再编译 

                变成type=燃油车,会出现语法错误,因为燃油车应该添加单引号,'${carType}'

使用${}

1、给sql语句传关键字(asc|desc)

<select>
  select * from car order by carNum ${key}
</select>

2、sql语句字段拼接,字段名例如:字段+日期

<select>
    //传入date
    select * from monster_${date}
</select>

3、批量删除,有两种写法in和or(动态sql)

<delete>
    //传入字符串 “1,2,3”
    delete form monster where id in (${ids})
</delete>

4、模糊查询

<select>
    //在jdbc中,'%?%'中的?不会被识别为占位符
    //传入name
    select * from `monster` where `name` like '%${name}%'
                                         like concat('%',#{name},'%')
                                         like "%"#{name}"%"使用较多
</select>

参数处理

入参-parameterType

使用Map

#{} 里写的是map集合的key,如果key不存在不会报错,数据库表中会插入NULL

使用Bean / List<Bean>

#{} 里写的是get方法的方法名去掉get之后将剩下的单词首字母变小写

getAge对应的是#{age},get方法不存在会报错。

使用多参数 

List<Student> selectByNameAndSex(String name, Character sex);
<select id="selectByNameAndSex" resultType="student">
  select * from t_student where name = #{name} and sex = #{sex}
</select>

name参数找不到,可用的参数包括[arg1, arg0, param1, param2]

在底层会创建一个map集合,以arg0/param1为key,以方法上的参数为value

Map<String,Object> map = new HashMap<>();
map.put("arg0", name);
map.put("arg1", sex);
map.put("param1", name);
map.put("param2", sex);

// 所以可以这样取值:#{arg0} #{arg1} #{param1} #{param2}
// 其本质就是#{map集合的key}

@Param注解(命名参数)

List<Student> selectByNameAndAge(@Param(value="name") String name
                                , @Param("age") int age);
List<Student> stus = mapper.selectByNameAndAge("张三", 20);
        stus.forEach(student -> System.out.println(student));

@Param("这里填写的其实就是map集合的key")

出参-resultType 

返回Map / List<Map>

当返回的数据,没有合适的实体类,可以采用Map集合接收

只有一条数据,则返回一个Map集合即可

    @MapKey("id")
    public List<Map<String,Object>> find(Map<String, Object> map);
<select id="find" parameterType="map" resultType="map">
        select * from `monster` where `id` > #{id} and `salary` >= #{salary}
</select>
@Test
    public void m4() {
        Map<String, Object> map = new HashMap<>();
        map.put("id",3);
        map.put("salary",1000);
        List<Map<String,Object>> monsterlist = monsterMapper.find(map);
        for (Map<String, Object> monsterMap : monsterlist) {
//            方式一
//            Set<String> keys = monsterMap.keySet();
//            for (String key : keys) {
//                System.out.println(key+ " " + monsterMap.get(key));
//            }
//            System.out.println("===========");
//            方式二
            for(Map.Entry<String,Object> entry : monsterMap.entrySet()) {
                System.out.println(entry.getKey()+ " " + entry.getValue());
            }
            System.out.println("=========");
        }
    }

返回Map<String,Map>

@MapKey("id")  
public Map<Integer,Map<String,Object>> findAll();
@Test
    public void find() {
        HashMap<String, Object> map = new HashMap<>();
        map.put("type","women");
        Map<Integer, Map<String, Object>> all = monsterMapper.findAll(map);
        System.out.println(all);
    }

属性名不一致-resultMap结果映射

select查询后,某些字段为null,是因为Bean的字段名和表的字段名不一致  

第一种(常用)

resultMap:
            id:这个结果映射的标识,作为select标签的resultMap属性的值。
            type:结果集要映射的类。可以使用别名。

主键使用id标签<id property="id" column="id"/>提高效率,其他都是<result>

当属性名和数据库列名一致时,可以省略。但建议都写上。

<resultMap id="carResultMap" type="car">
  <id property="id" column="id"/>
  <result property="useremail" column="user_email"/>
  <result property="username" column="user_name"/>
</resultMap>

<select id="selectAllByResultMap" resultMap="carResultMap">
  select * from t_car
</select>

第二种

在写sql语句的时候写别名,跟Bean的字段名保持一致

第三种

开启驼峰命名自动映射

<settings>
    <setting name="mapUnderscoreToCamelCase" value="true"/>
</settings>

前提:

        java命名规范:首字母小写,后面每个单词首字母大写,遵循驼峰命名规范

        sql命名规范:全部小写,单词之间采用下划线分割

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2263626.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

机器学习探索之旅:开启智能预测的新篇章!!! 笔记 ! ! !)

目录 一 . 机器学习基础&#xff1a; 1. 什么是机器学习&#xff1a; Langley&#xff08;1996&#xff09;的定义&#xff1a; Tom Mitchell&#xff08;1997&#xff09;的定义&#xff1a; 冷雨泉&#xff08;等&#xff09;的观点&#xff1a; 2. 机器学习与人工智能…

【RAII | 设计模式】C++智能指针,内存管理与设计模式

前言 nav2系列教材&#xff0c;yolov11部署,系统迁移教程我会放到年后一起更新&#xff0c;最近年末手头事情多&#xff0c;还请大家多多谅解。 上一节我们讲述了C移动语义相关的知识&#xff0c;本期我们来看看C中常用的几种智能指针&#xff0c;并看看他们在设计模式中的运…

基于单片机的病房呼叫系统设计

摘 要&#xff1a; 文章基于 51 系列的单片机设计的病房呼叫系统 。 在以 AT89C51 单片机为核心&#xff0c;以 74HC573 锁存器 、数码管显示模块、 矩阵按键模块等为辅组成的&#xff0c;按键分布在各个病床的床头&#xff0c;可以节约接口资源&#xff0c;当按下按键&a…

编译原理复习---目标代码生成

适用于电子科技大学编译原理期末考试复习。 1. 目标代码 是目标机器的汇编代码或机器码&#xff0c;在本课程中指的是类似于汇编代码的一种形式&#xff0c;由一条条的指令构成目标代码。 抽象机指令格式&#xff1a;OP 目的操作数&#xff0c;源操作数。 我们要做的&…

Redis数据对象

基本结构图 key和value指向的是redisObject对象 type&#xff1a;标识该对象用的是什么类型&#xff08;String、List Redis数据结构 SDS SDS有4个属性&#xff1a; len&#xff1a;记录了字符串长度&#xff0c;因此获取字符串长度的时候时间复杂度O&#xff08;1&#xff…

Gale-Shapley算法

一. 设计目的 盖尔-沙普利算法&#xff08;Gale-Shapley算法&#xff09;的设计目的是为了解决稳定匹配问题&#xff0c;即在给定一组男性和女性的偏好列表的情况下&#xff0c;找到一个稳定的匹配。这里的“稳定”指的是不存在任何一对男性和女性&#xff0c;他们彼此都比当前…

JWT令牌与微服务

1. 什么是JWT JWT&#xff08;JSON Web Token&#xff09;是一种开放标准(RFC 7519)&#xff0c;它定义了一种紧凑且自包含的方式&#xff0c;用于作为JSON对象在各方之间安全地传输信息。JWT通常用于身份验证和信息交换。 以下是JWT的一些关键特性&#xff1a; 紧凑&#xff…

视频点播系统|Java|SSM|VUE| 前后端分离

【技术栈】 1⃣️&#xff1a;架构: B/S、MVC 2⃣️&#xff1a;系统环境&#xff1a;Windowsh/Mac 3⃣️&#xff1a;开发环境&#xff1a;IDEA、JDK1.8、Maven、Mysql5.7 4⃣️&#xff1a;技术栈&#xff1a;Java、Mysql、SSM、Mybatis-Plus、VUE、jquery,html 5⃣️数据库可…

docker部署Melody开源音乐管理工具

Melody是一款非常实用的开源音乐管理工具。它不仅功能强大、操作简便&#xff0c;还支持多平台检索和一键下载/上传功能。更重要的是&#xff0c;它还支持一键“解锁”无法播放的歌曲和多端适配。如果你也是音乐爱好者&#xff0c;不妨试试Melody&#xff0c;让你的音乐生活更加…

问题小记-达梦数据库报错“字符串转换出错”处理

最近遇到一个达梦数据库报错“-6111: 字符串转换出错”的问题&#xff0c;这个问题主要是涉及到一条sql语句的执行&#xff0c;在此分享下这个报错的处理过程。 问题表现为&#xff1a;一样的表结构和数据&#xff0c;执行相同的SQL&#xff0c;在Oracle数据库中执行正常&…

day4:tomcat—maven-jdk

一&#xff0c;java项目部署过程 编译&#xff1a;使用javac命令将.java源文件编译成.class宇节码文件打包&#xff1a;使用工具如maven或Gradle将项目的依赖、资源和编译后的字节码打包成一个分发格式&#xff0c;如.jar文件&#xff0c;或者.war文件(用于web应用&#xff09…

【D3.js in Action 3 精译_046】DIY 实战:在 Observable 平台利用饼图布局函数实现 D3 多个环形图的绘制

当前内容所在位置&#xff1a; 第五章 饼图布局与堆叠布局 ✔️ 5.1 饼图和环形图的创建 ✔️ 5.1.1 准备阶段&#xff08;一&#xff09;5.1.2 饼图布局生成器&#xff08;二&#xff09;5.1.3 圆弧的绘制&#xff08;三&#xff09;5.1.4 数据标签的添加&#xff08;四&#…

Swin transformer 论文阅读记录 代码分析

该篇文章&#xff0c;是我解析 Swin transformer 论文原理&#xff08;结合pytorch版本代码&#xff09;所记&#xff0c;图片来源于源paper或其他相应博客。 代码也非原始代码&#xff0c;而是从代码里摘出来的片段&#xff0c;配上简单数据&#xff0c;以便理解。 当然&…

Vscode搭建C语言多文件开发环境

一、文章内容简介 本文介绍了 “Vscode搭建C语言多文件开发环境”需要用到的软件&#xff0c;以及vscode必备插件&#xff0c;最后多文件编译时tasks.json文件和launch.json文件的配置。即目录顺序。由于内容较多&#xff0c;建议大家在阅读时使用电脑阅读&#xff0c;按照目录…

麒麟操作系统服务架构保姆级教程(二)sersync、lsync备份和NFS持久化存储

如果你想拥有你从未拥有过的东西&#xff0c;那么你必须去做你从未做过的事情 上篇文章我们说到rsync虽好&#xff0c;但是缺乏实时性&#xff0c;在实际应用中&#xff0c;咱们可以将rsync写进脚本&#xff0c;然后写进定时任务去备份&#xff0c;如果每天凌晨1&#xff1a;00…

关于小程序内嵌h5打开新的小程序

关于小程序内嵌h5打开新的小程序 三种方式 https://juejin.cn/post/7055551463489011749 只依赖于h5本身的就是 https://huaweicloud.csdn.net/64f97ebb6b896f66024ca16c.html https://juejin.cn/post/7055551463489011749 navigateToMiniProgram 故小程序webview里的h5无法…

QP:Query切词

Query 分词&#xff08;切词&#xff09; 分词指将一段连续的文本切成一个个独立且有意义的词汇&#xff0c;在文本召回中会对 Doc 文本内容分词以构建索引&#xff0c;并通过对查询词 Query 分词后去做检索。Query 分词在搜索中是一个基础信号&#xff0c;除了文本召回&#…

鸿蒙元服务从0到上架【第二篇】

第一招&#xff1a;在AppGallery后台下载对应的证书等文件 AppGallery后台 新增发布证书&#xff0c;具体操作可查看申请发布证书 申请发布Profile证书 第二招&#xff1a;在IDE中填写 第三招&#xff1a;打包【⚠️发布上架的只能是Build App】 终端展示这一片绿&#xf…

9_HTML5 SVG (5) --[HTML5 API 学习之旅]

SVG 模糊效果 HTML5中的SVG&#xff08;可缩放矢量图形&#xff09;允许我们创建高质量的二维图形&#xff0c;包括应用各种滤镜效果。模糊效果是通过<feGaussianBlur>滤镜原语来实现的。下面我将给出4个使用SVG进行模糊效果处理的示例&#xff0c;并为每个代码段添加详…

vue+node+mysql8.0,详细步骤及报错解决方案

1.下载需要安装的插件 下载express npm install express下载cors&#xff0c;用于处理接口跨域问题 npm install cors下载mysql npm install mysql 2.配置服务器 可以在vue项目的src同级创建server文件夹&#xff08;这里的位置可随意选择&#xff09; 然后依次创建&#…