MyBatis-获取参数

1. 创建MyBatis配置文件模板

  1. 编辑完Mybatis核心配置文件和properties文件后,打开IDEA的设置界面,找到Editor中的File and Code Templates,点击加号新增模板。在这里插入图片描述
  2. 接着将编辑好的核心配置文件中的内容复制粘贴到空白框中,设置好模板名等内容即可。在这里插入图片描述
  3. 接下来右键点击,选择new,就能直接使用创建好的模板了。在这里插入图片描述

2. 创建映射文件的模板

照着上述步骤来即可。
在这里插入图片描述

3. 创建工具类来完成获得mapper对象的功能

import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;import java.io.IOException;
import java.io.InputStream;public class SqlSessionUtils {public static SqlSession getSqlSession() throws IOException {InputStream resourceAsStream = Resources.getResourceAsStream("mybatis-config.xml");SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();SqlSessionFactory build = sqlSessionFactoryBuilder.build(resourceAsStream);return build.openSession(true);}}

在这里插入图片描述

4. MyBatis获取参数的两种方式

MyBatis由两种方式来获取参数:

  • ${}:本质为字符串拼接,需要注意sql注入问题
  • #{}:本质为占位符复制

4.1 传入单个字面值

    <!--根据id查询用户当传入单个字面值时,可以使用任意名称来获取参数值,因为传参不以参数名为准,而是以位置为准要注意${}方法的单引号问题--><select id="getUserById" resultType="User"><!--使用#{},可以用任意名称接收参数甚至是字面值--><!--select * from user where id=#{2};--><!--使用${},可以使用任意名称接收参数,但需要注意双引号,否则会报错因为此方法为字符串拼接,如果参数是字符串类型,那么拼接后的字符串不带引号,所以会报错-->select * from user where id='${2}'</select>

4.2 传入多个字面值

    <!--当传入多个字面值时,mybatis会将这些参数放在一个map集合中以arg0,arg1...(或param1,param2...)为键,参数值为值所以要通过map中的键来获取相应的值--><select id="getUserByUsernameAndAge" resultType="User"><!--根据map中的键来获取参数值--><!--select * from user where username=#{arg0} and age=#{param2}-->select * from user where username='${param1}' and age=${arg1}</select>

4.3 自定义Map传入

    <!--可以自己将传入的参数放在一个map集合中,就可以使用自定义的键来获取参数值了--><insert id="insertUser"><!--insert into user values (#{id},#{username},#{password},#{age},#{sex},#{email})-->insert into user values (${id},'${username}','${password}',${age},'${sex}','${email}')</insert>
    @Testpublic void test4() throws IOException {SqlSession sqlSession = SqlSessionUtils.getSqlSession();UserDao mapper = sqlSession.getMapper(UserDao.class);Map<String,Object> map = new HashMap<>();map.put("id",4);map.put("username","hellen");map.put("password","12386kk");map.put("age",22);map.put("sex","女");map.put("email","jn@asd.com");Integer i = mapper.insertUser(map);System.out.println(i);}

4.4 传入实体类对象

    <!--当传入参数为实体对象时,可以通过属性名直接获取属性值要注意,在这里的属性实际上不需要对象中必须有对应字段只要有相应的get方法,去掉get后将首字母小写,得到的就是属性名,这个属性值就可以通过属性名获取--><insert id="insertUserByClass"><!--insert into user values (#{id},#{username},#{password},#{age},#{sex},#{email})-->insert into user values (${id},'${username}','${password}',${age},'${sex}','${email}');</insert>
    @Testpublic void test5() throws IOException {SqlSession sqlSession = SqlSessionUtils.getSqlSession();UserDao mapper = sqlSession.getMapper(UserDao.class);Integer i = mapper.insertUserByClass(newUser(6, "jcack", "aasddscx", 33, '女'));System.out.println(i);}

4.5 使用@Param注解命名参数

    <!--当使用了@Param注解命名了参数后,多个参数在map中就以自定义的名称为键(或param1,param2...为键),参数值为值在获取参数时可以直接使用自定义的参数名获取--><select id="getUserByUsernameAndSex" resultType="User">select * from user where username=#{username} and sex='${param2}'</select>

5.

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

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

相关文章

Android为现有的应用工程设置 Compose

点击查看&#xff1a;Compose 快速入门 点击查看&#xff1a;Jetpack Compose 与 Kotlin 的兼容性对应关系 要开始使用 Compose&#xff0c;您需要先向项目中添加一些 build 配置。将以下定义添加到应用的 build.gradle 或者build.gradle.kts 文件中&#xff1a; build.gradle…

嵌入式学习day23 Linux

时间获取: 1.time time_t time(time_t *tloc); 功能: 返回1970-1-1到现在的秒数&#xff08;格林威治时间&#xff09; 参数: tloc:存放秒数空间首地址 返回值: 成功返回秒数 失败返回-1 2.localtime str…

计算机专业有关的几部电影

推荐几部计算机专业必看的几部电影&#xff1a; 《黑客帝国》&#xff08;The Matrix&#xff09; 这部电影是科幻电影的经典之作&#xff0c;它展示了一个由机器控制的虚拟现实世界。影片中的计算机特效和对虚拟现实的描绘&#xff0c;对于理解计算机图形学和人工智能的概念…

力扣(leetcode)第485题最大连续1的个数(Python)

485.最大连续1的个数 题目链接&#xff1a;485.最大连续1的个数 给定一个二进制数组 nums &#xff0c; 计算其中最大连续 1 的个数。 示例 1&#xff1a; 输入&#xff1a;nums [1,1,0,1,1,1] 输出&#xff1a;3 解释&#xff1a;开头的两位和最后的三位都是连续 1 &#x…

代码随想录第二十一天 701.二叉搜索树中的插入操作 108.将有序数组转换为二叉搜索树

701.二叉搜索树中的插入操作 题目描述 给定二叉搜索树&#xff08;BST&#xff09;的根节点 root 和要插入树中的值 value &#xff0c;将值插入二叉搜索树。 返回插入后二叉搜索树的根节点。 输入数据 保证 &#xff0c;新值和原始二叉搜索树中的任意节点值都不同。 注意&a…

RESTful 风格是指什么

RESTful&#xff08;Representational State Transfer&#xff09;是一种基于 HTTP 协议的软件架构风格&#xff0c;用于设计网络应用程序的接口。它的设计理念是利用 HTTP 协议中的方法&#xff08;如 GET、POST、PUT、DELETE 等&#xff09;来对资源进行 CRUD&#xff0c;使得…

目前最新的基于Debian12的树莓派系统换源方式

前言 树莓派目前最新为debian12系统&#xff0c;网上有很多旧的换源方式&#xff0c;随着系统更新不一定有效 流程 sudo cp /etc/apt/sources.list /etc/apt/sources.list.backup 备份旧的数据 sudo nano /etc/apt/sources.list编辑sources.list文件 deb http://mirrors.…

上传代码到云效

1.获得邀请链接&#xff0c;加入工作台 > 点击代码管理 2.创建代码库后 > 点击克隆下载 > 复制https链接 3.如果未安装git客户端先安装 > 选择一个本地文件夹右击鼠标点击Git Bash Here打开git命令窗 4.克隆时提示输入账号密码&#xff0c;在云效个人设置页面Ht…

利用MATLAB/Simulink仿真模型加速嵌入式控制系统的开发——以多学科融合的电机控制为例

电机控制涵盖了广泛的应用领域&#xff0c;从家用电器到工业设备&#xff0c;从电动汽车到航空航天&#xff0c;其重要性不言而喻。从过去到现在&#xff0c;再到未来&#xff0c;电机控制技术的发展经历了显著的变革&#xff0c;并持续推动着相关行业的进步。 一、电机控制的…

基于Jenkins实现的CI/CD方案

基于Jenkins实现的CI/CD方案 前言 最近基于Jenkins的基座&#xff0c;搭建了一套适用于我们项目小组的持续集成环境。现在把流程整理分享出来&#xff0c;希望可以给大家提供一些帮助和思路。 使用到的组件和版本 组件名称组件版本作用Harbor2.7.3镜像仓库Jenkins2.319.2持…

fastApi笔记03-请求体

请求体是客户端发送给API的数据&#xff0c;fastApi使用 Pydantic 模型来声明请求体 不能使用 GET操作&#xff08;HTTP 方法&#xff09;发送请求体。 要发送数据&#xff0c;必须使用下列方法之一&#xff1a;POST&#xff08;较常见&#xff09;、PUT、DELETE 或 PATCH 创…

zabbix5.0利用percona监控MySQL

具体来说包括: Percona Monitoring Plugins 这是一组用于收集MySQL实例各种性能指标和状态的插件脚本,包括: mysqld_stats.pl - 收集服务器状态计数器mysqld_statement_replay.pl - 进行负载模拟测试pt-status - 收集InnoDB资源使用情况等 Percona Templates 基于这些插件收集…

博途PLC PID仿真(单容水箱液位高度控制)

单容水箱和双荣水箱的微分方程和数值求解,可以参考下面文章链接: https://rxxw-control.blog.csdn.net/article/details/131139432https://rxxw-control.blog.csdn.net/article/details/131139432这篇博客我们利用欧拉求解器在PLC里完成单容水箱的数学建模。PLC也可以和MATL…

一次平平无奇的 Oracle 注入

在某次项目中&#xff0c;首先是发现注入点&#xff0c;数据库是Oracle&#xff0c;利用方式是时间盲注&#xff1a; 因为需要具体数据&#xff0c;所以要深入利用&#xff0c;手工肯定不方便&#xff0c;所以直接上 Sqlmap: Sqlmap也可以扫出该注入点&#xff0c;但想要进一步…

C++数组实战——考试成绩统计

成绩一成绩二成绩三同学一100100100同学二607999同学三1009587 代码&#xff1a; #include <iostream> #include<string> using namespace std;int main() { int score[3][3] {{100,100,100},{60,79,99},{100,95,87},}; #定义分数二维数组string names[3]{&qu…

monaco脚本编辑器 在无界中使用 鼠标点击不到

背景A项目使用无界引入B项目 经排查&#xff0c;是B使用的的monaco脚本编辑器无法在A的无界框架中引入的问题。 经查询&#xff0c;需要修改monaco源码来使之能在无界中使用。 解决方案&#xff1a;https://github.com/Tencent/wujie/issues/205。 有三种解决方案&#xff1a; …

软件实际应用,物流运输货运单打印,打印样式模板可以定制

软件实际应用&#xff0c;物流运输货运单打印&#xff0c;打印样式模板可以定制 一、前言 以下软件程序教程以 佳易王物流单打印查询系统V17.0为例说明 软件文件下载可以点击最下方官网卡片——软件下载——试用版软件下载 1、 物流单起始站可以设置直接选择&#xff0c;到达…

ARM 之十六 详解 CMSIS 版本变迁、各组件使用示例

目前,CMSIS 已经发展到了第六版,其目录结构也发生了重大的变化。在不断发展中,很多原来 CMSIS 的组件被不断独立出去,并因此成立了很多开源社区,今天就来学习一下! 由于 CMSIS 已经包含了相当丰富的文档,因此,本文重点学习版本之间的变化以及一些实际使用示例。 什么是…

C#的三种小数类型 decimal和double , float

在 C# 中&#xff0c;decimal、double 和 float 都是用来表示浮点数的数据类型&#xff0c;它们在内存中的存储方式和精度有所不同。 decimal&#xff1a; decimal 类型用于存储十进制数&#xff0c;适用于对小数精度要求较高的情况&#xff0c;比如财务计算。decimal 类型占据…

2024云服务器ECS_云主机_服务器托管_e实例-阿里云

阿里云服务器ECS英文全程Elastic Compute Service&#xff0c;云服务器ECS是一种安全可靠、弹性可伸缩的云计算服务&#xff0c;阿里云提供多种云服务器ECS实例规格&#xff0c;如ECS经济型e实例、通用算力型u1、ECS计算型c7、通用型g7、GPU实例等&#xff0c;阿里云服务器网al…