MyBatis的使用

news2025/1/23 2:12:14

一.在创建Spring项目时引入MyBatis Framework和MySQL Driver;

二.下载插件:MyBatisX插件。

三.配置文件:

四.根据MyBatis写法完成数据库的操作

     常规写法,包括两个文件:

      1.接口:方法的声明(给其他层调用(Service)调用)

      2.XML: 实现接口

    步骤:1.定义Mapper接口,

                2.编写XML文件:namespace的内容要与之前定义的Mapper接口相对应。并在mapper里写SQL语句。

条件语句:可以用#{},或${}:

#{}与${}的区别:

        1.#{}与JDBC的prepareStatement类似,先将该地方的值换位?,再把传过来的参数换位String类型变成一条完整的SQL语句应用于大多数场景;

        2.${}是直接替换,其应用场景一般为类似于select * from userinfo order by id ${myorder}等可以直接替换的情况。

删除语句:<delete>,只需填写id即可。id为对应的Mapper类里的对应的方法名。

修改操作:<update>,只需填写id即可。id为对应的Mapper类里的对应的方法名。在set属性值时,用#{}可以直接写对应的类的属性名,不必写类名.get属性名()。

添加语句:<insert>,只需填写id即可。id为对应的Mapper类里的对应的方法名。

需要设置主键时,用useGeneratedKeys="true",表示设置主键,keyColumn:设置主键值在数据库表的属性名,keyProperty:设置表的属性名对应的类的属性名

 查询语句:用<select>标签,id填写对应Mapper接口对应的方法,resultType写定义的接收对应sql数据的model类的位置。

like查询:

注意:不能写成select * from userinfo where username like '%#{username}%',因为#{},会先用?代替此处的值,然后把传过来的变量变为String类型,导致变为:select * from userinfo where username like '%'username'%',无法通过。解决方法:

1.可以通过concat方法将'%','#{username}','%'拼在一起。

2.也可以直接写为select * from userinfo where username like '%${username}%'。

类中的属性和数据库表中的字段名不一致时:

       类中的属性和数据库表中的字段名不一致时,那么查询的结果为null,解决方案:

              1.将类中的属性和数据库表中的字段名保持一致。

              2.使用sql语句中的as进行列名(字段名)重命名,让列名(字段名)等于属性名。

 

              3.使用ResultMap,属性名和字段名进行手动映射(最好全部都设好,防止多表查询时出问题),column是数据库的字段名,property是定义的类的属性名。

在相应的sql字段里设置ResultMap。

新版本写法:只需要注解。

注解里的内容就是常规写法对应sql标签里的内容。

动态sql:

出现动态sql的原因:在数据库中null不等于空。

<if>标签:

语法:

<if test="条件(类似于if条件()里的语句)">

...

</if>

<trim>标签

属性:prefix:表示整个语句块,以prefix的值作为前缀(里面的东西加在标签内的内容之前)

           suffix:表示整个语句块,以suffix的值作为后缀(里面的东西加在标签内的内容之后)    

           prefixOverrides:表示整个语句块要去除的前缀

           suffixOverrides:表示整个语句块要去除的后缀

suffixOverride的作用在于如果最后一个变量等于null,则不执行<if>里的内容,会导致sql语句在最后多了个逗号进而无法执行。

<where>:

<where>标签的存在是因为如果直接写成where+<if>的组合,若<if>内的条件不满足,无法执行,就会因为多一个where而使sql无法执行。<where>标签可以根据<where>标签中的内容决定是否生成"where"关键字,去除最前面的"and"关键字。

<set>:

<set>标签可以根据<set>标签中的内容决定是否生成"set"关键字,去除最后面的","。可与<trim prefix="set"  suffixOverrides=",">替换。

<foreach>:

属性:

collection:绑定方法参数中的集合,如List,Set,Map或数组对象

item:遍历时的每一个对象

open:语句块开头的字符串

close:语句块结束的字符串

separator:每次遍历之间间隔的字符串。

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

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

相关文章

CAN/CANFD转WIFI设备解决近距离无线通讯问题

在现场应用中&#xff0c;各种情况都会出现&#xff0c;一些运动设备进行维护、下载、测试工作时&#xff0c;需要近距离无线收发CAN/CANFD报文。 港口应用中&#xff0c;控制室与吊机一没有办法通过有线连接&#xff0c;这时候就可以用无线来实现数据抓取。 例如某AGV小车厂…

java.lang.ClassCastException: android.os.BinderProxy cannot be cast to ...

项目开发遇到下面这个报错了&#xff01; 直接说原因&#xff0c;就是因为进程间不能直接传递对象&#xff0c;应该传递该Binder对象的映射&#xff08;代理对象&#xff09;&#xff0c;所以类型转换就出错了。如果在同一个进程中&#xff0c;直接传递对象没有关系&#xff0c…

手撕代码是程序员的基本功吗?

前言&#xff1a; 现在众多企业都要求在面试中用“手撕代码”来考验应聘者的代码能力&#xff0c;你觉得手敲代码是否可以体现真实的基础实力&#xff1f; 本期话题&#xff1a; 1、你觉得手撕代码是程序员的基本功吗&#xff1f; 2、为什么会用“手撕代码”来考验程序员能力&a…

vue3中v-html的使用时,出现<后面的字符串展示不出来

话不多说&#xff0c;直接上代码&#xff1a; 把<替换一下用&lt &#xff0c;这样就完美的解决问题了

神经网络 01(介绍)

一、神经网络 人工神经网络 (Artificial Neural Network&#xff0c;简写为ANN)也简称为神经网络 (NN)&#xff0c;是一种模仿生物神经网络结构和功能的 计算模型。人脑可以看做是一个生物神经网络&#xff0c;由众多的神经元连接而成。各个神经元传递复杂的电信号&#xff0c…

有趣不失风度:sdxl-emoji模型上线,在线生成苹果Memoji头像

苹果公司即将举行发布会&#xff0c;这是每年吸引全球关注的重大事件。在这期间&#xff0c;众多第三方软件也开始推出与苹果相关的应用程序。其中&#xff0c;sdxl-emoji是一款基于AI技术的绘图模型&#xff0c;已经上线&#xff0c;并且还开发了基于该模型的在线Demo。这款应…

springboot3 + java虚拟线程初体验

java虚拟线程介绍 虚拟线程是 Java 19 的 预览特性&#xff0c;估计会在Java 22被纳入 JDK 的正式版本中&#xff0c;会在2023年9月发布&#xff0c;目前springboot 3 已经提供了对虚拟线程的支持。 虚拟线程和平台线程主要区别在于&#xff0c;虚拟线程在运行周期内不依赖操…

【项目分析】仿linux0.11的操作系统内核

系列综述&#xff1a; &#x1f49e;目的&#xff1a;本系列是个人整理为了秋招面试的&#xff0c;整理期间苛求每个知识点&#xff0c;平衡理解简易度与深入程度。 &#x1f970;来源&#xff1a;材料主要源于《操作系统 真象还原》及各大佬博客进行的&#xff0c;每个知识点的…

linux系统移植简要过程(移植bootloader引导加载程序---移植linux内核---制作根文件系统)

一.标准linux启动过程图 对于linux启动流程分析&#xff0c;我们需要移植bootloader引导加载程序---移植linux内核---制作根文件系统镜像文件&#xff1b; 二.为什么进行系统移植&#xff1f; 对于不同的硬件平台&#xff0c;linux系统启动流程大体相同&#xff0c;但是资源需求…

Multisim14.0仿真(十二)积分放大器

一、仿真原理图&#xff1a; 二、仿真效果图&#xff1a;

道路积水监测-路面积水监测系统

随着城市化的不断发展&#xff0c;城市面临着越来越多的交通挑战&#xff0c;其中之一就是道路积水问题。道路积水不仅影响了交通安全&#xff0c;还会引发交通堵塞、交通事故和城市洪涝等问题。因此&#xff0c;开展道路积水监测是十分必要的。 城市排水、供水、燃气、供热、桥…

本地部署kubesphere集群

本地部署kubesphere集群 本文采用一主两从结构 1.前置硬件准备 准备最少3台机器&#xff0c;本人分配如下 IP&#xff1a;192.168.58.10 &#xff08;主&#xff09; 192.168.58.11 &#xff08;节点1&#xff09; 192.168.58.12 &#xff08;节点2&#xff09; 系统镜像…

3.linux的进程和服务管理

一、查看进程 1.Linux的进程介绍 1)在 LINUX 中,每个执行的程序(代码)都称为一个进程。每一个进程都分配一个ID号。 2)每一个进程,都会对应一个父进程,而这个父进程可以复制多个子进程。 3)每个进程都可能以两种方式存在的。前台与后台 4)一般系统的服务都是以后台进程的方…

icmp报文及用go实现

目录 一、概述 二、ICMP报文格式详解 2.1 什么是ICMP 2.2 ICMP报文格式 2.3 ICMP报文类型 2.4 实际报文举例 三、使用go实现icmp请求以及接收响应内容 一、概述 本文主要旨在学习icmp报文格式&#xff0c;以及通过go语言来实现ICMP发包。 二、ICMP报文格式详解 2.1 什…

Redis缓存设计与性能优化

多级缓存架构 缓存设计 缓存穿透 缓存穿透是指查询一个根本不存在的数据&#xff0c; 缓存层和存储层都不会命中&#xff0c; 通常出于容错的考虑&#xff0c; 如果从存储层查不到数据则不写入缓存层。缓存穿透将导致不存在的数据每次请求都要到存储层去查询&#xff0c; 失去…

【解决】80端口被占用,无法启动apache

1.cmd输入netstat -nao,查看是什么进程占用80端口。进程显示为pid4。 2.打开任务管理器&#xff0c;详细信息选项卡&#xff0c;可以看到pid4的进程是system。 右键打开文件所在位置&#xff0c;可以看到是ntoskrnl.exe这个文件占用80端口 3.【解决方法】 &#xff08;1&am…

开源即时通讯(IM)项目OpenIM源码部署流程

由于OpenIM依赖的组件较多&#xff0c;开发者需求不一&#xff0c;导致OpenIM部署一直被人诟病&#xff0c;经过几次迭代优化&#xff0c;包括依赖的组件compose的一键部署&#xff0c;环境变量设置一次&#xff0c;全局生效&#xff0c;以及脚本重构&#xff0c;目前OpenIM部署…

淘宝直通车智能计划怎么开?

很多中小卖家不会开直通车&#xff0c;会遇到整个直通车账户亏钱又对店铺没起到正向作用的问题&#xff0c;开车目的也不明确。对于小卖家&#xff0c;店铺最缺的就是流量&#xff0c;那么如何解决流量问题&#xff1f;今天我教大家一种直通车低价引流的打法。 具体步骤&…

【halcon】halcon字符识别——OCR

前言 OCR&#xff08;Optical Character Recongnition&#xff09;光学字符识别。 halcon 的OCR&#xff0c;提供了几种方式&#xff0c;我们应该如何选择&#xff1f; 自动文本阅读器&#xff08;find_text&#xff09;手动文本阅读器&#xff08;find_text&#xff09;自己…

IDEA安装翻译插件

IDEA安装翻译插件 File->Settings->Plugins 在Marketplace中&#xff0c;找到Translation&#xff0c;点击Install 更换翻译引擎 勾选自动翻译文档 翻译 鼠标右击->点击Translate