MyBatis搭建和增删改查

news2024/11/14 18:41:47

MyBatis是一个开源的持久层框架,用于处理数据库的增删改查操作。它能够将Java对象与数据库中的数据进行映射关系的配置,并自动生成对应的SQL语句,从而简化了数据库操作的编码工作。

MyBatis的核心思想是将SQL语句与Java代码分离,通过XML或注解来配置SQL语句,使得SQL语句可以进行灵活的管理和维护。通过MyBatis,开发人员可以使用面向对象的思维来进行数据库操作,而不需要直接编写繁琐的SQL语句。

ORM(Object Relational Mapping,对象关系映射)是一种数据持久化技术,它在对象模型和关系型数据库之间建立起对应关系,并且提供了一种机制,通过 JavaBean 对象去操作数据库表中的数据。


关于Maven的相关配置见之前的博客:Maven项目搭建

搭建MyBatis

1. 配置依赖项

在pom.xml文件中配置Mybatis依赖库和SQL链接库等

        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>2.2.2</version>
        </dependency>
		
		<dependency>
    		<groupId>mysql</groupId>
    		<artifactId>mysql-connector-java</artifactId>
    		<version>8.0.26</version>
		</dependency>

2. 配置数据源

在resources文件夹下创建application.yml配置文件

yml基本语法

#注释用井号

名称跟冒号:

  属性前面空两格: 值前面空一格

    - 数组元素用短横线加空格

#配置mybatis的数据源 DataSource
spring:
  datasource:
    username: root
    password: 123123
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://localhost:3306/easydata

3.创建封装类

package com.easy.bean;

import java.math.BigDecimal;

public class Staff {
	private int id;
	private String code;
	private String name;
	private BigDecimal salary;
	private String username;
	private String userpass;

    //这里省略getter和setter方法...
}

4.定义Mapper

在resources文件夹下创建一个mapper文件夹用于存放mapper的xml文件

在该目录下新建应该xml文件:

mapper 标签内指定连接的对应接口是 com.easy.dao.IStaffDao

标签之间写SQL语句,在 id 中指明调用的方法名,resultType 指定返回值类型小写

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.easy.dao.IStaffDao">
	<!-- 在这里写SQL语句 -->
	<select id="getNow" resultType="string">
		select now()
	</select>

</mapper>

5.配置Mapper文件路径和别名以及日志级别

在application.yml文件中配置以下内容:

#配置mapper的xml文件位置
mybatis:
  mapper-locations: classpath:mapper/*.xml
#用于打印日志
logging:
  level:
    com.easy.dao: debug

6.定义数据访问层接口

在com.easy包下建一个dao包用于定义数据访问层的接口,接口用 @Mapper 注解

package com.easy.dao;

import org.apache.ibatis.annotations.Mapper;

import com.easy.bean.Staff;

@Mapper
public interface IStaffDao {

	String getNow();

}

7.编写业务处理层(可以使用面向接口)

在controller包下编写控制类,使用 @RestController 注解,

类内用 @Autowired 注入接口,并在方法上使用 @GetMapping 等指定请求方式

@RestController
public class EasyController {
	@Autowired
	IStaffDao dao;

	@GetMapping("now")
	public String now() {
		return dao.getNow();
	}
}

浏览器测试输出:


参数传递

这里以通过姓名和编号查询staff员工表为例

mapper的对应xml文件中编写SQL语句:

	<select id="getStaff" resultType="com.easy.bean.Staff">
		select * from staff where name=#{name} and code=#{code}
	</select>

1.使用注解传递参数

在接口中定义方法:

@Mapper
public interface IStaffDao {
	List<Staff> getStaff(@Param("name")String name,@Param("code")String code);
}

控制类中编写 getStaff 方法:

	@GetMapping("staff")
	public List<Staff> getStaff(@RequestParam("name")String name,@RequestParam("code")String code) {
		List<Staff> staffs = dao.getStaff(name, code);
		return staffs;
	}

2.使用Map传递参数

在接口中定义方法:

@Mapper
public interface IStaffDao {	
	List<Staff> getStaff(Map params);
}

控制类中编写 getStaff 方法:

	@GetMapping("staff")
	public List<Staff> getStaff(@RequestParam Map map) {
		List<Staff> staffs = dao.getStaff(map);
		return staffs;
	}

3.使用JavaBean传递参数

在接口中定义方法:

@Mapper
public interface IStaffDao {
	List<Staff> getStaff(Staff staff);
}

控制类中编写 getStaff 方法:

	@GetMapping("staff")
	public List<Staff> getStaff(Staff staff) {
		List<Staff> staffs = dao.getStaff(staff);
		return staffs;
	}

区别:

  • 使用 Map 传递参数会导致业务可读性的丧失,继而导致后续扩展和维护的困难,所以在实际应用中我们应该果断废弃该方式。
  • 使用 @Param 注解传递参数会受到参数个数的影响。当 n≤5 时,它是最佳的传参方式,因为它更加直观;当 n>5 时,多个参数将给调用带来困难。
  • 当参数个数大于 5 个时,建议使用 JavaBean 方式。

占位符#和$的区别

SQL语句分为两个过程:编译,执行。在MyBatis中,#$是两种不同的占位符用法。

# 预编译的占位符,使用#时,MyBatis会对传入的参数进行预处理,类型解析之后,将参数的值安全地替换到SQL语句中。例如,使用#{param}占位符时,MyBatis会将参数值作为字符串的形式传递给数据库,这样可以防止SQL注入攻击。

$ 直接替换的占位符,使用$时,MyBatis会将占位符替换为参数的字符串值。例如,使用${param}占位符时,MyBatis会直接将参数的值替换到SQL语句中,不进行预处理。这意味着,使用$时需要注意安全性和潜在的SQL注入风险,因为参数值直接拼接到SQL语句中,可能会导致不安全的查询。

总结来说,#符号用于预处理参数,提高安全性,而$符号用于直接替换参数,更加灵活但需要注意安全性。在实际使用中,一般推荐使用#符号,除非有特殊需求,需要动态拼接SQL语句时才使用$符号。

注:SQL注入是一种常见的安全漏洞,指的是攻击者通过在应用程序中注入恶意的SQL代码,使得应用程序在处理SQL语句时执行了攻击者意图的代码。

当使用$占位符时,如替换的内容为 ' or '1'='1  直接替换会导致SQL语句执行了不符合本意的逻辑。


映射文件常用标签

1.select标签

为了使数据库的查询结果和返回值类型中的属性能够自动匹配,通常会对 MySQL 数据库和 JavaBean 采用同一套命名规则,即 Java 命名驼峰规则,这样就不需要再做映射了(数据库表字段名和属性名不一致时需要手动映射)。

常用属性

2.insert标签

MySQL、SQL Server 等数据库表可以采用自动递增的字段作为其主键,当向这样的数据库表插入数据时,即使不指定自增主键的值,数据库也会根据自增规则自动生成主键并插入到表中。

	<insert id="addStaff">
		insert into staff(code,name,salary,username,userpass)
		value(#{code},#{name},#{salary},#{username},#{userpass})
	</insert>

3.update标签

	<update id="editStaff">
		update staff set name=#{name},salary=#{salary},username=#{username},
		userpass=#{userpass} where id=#{id}
	</update>

4.delete标签

	<delete id="delStaff">
		delete from staff where id=#{id}
	</delete>

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

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

相关文章

Java01 Java预备知识

第一节&#xff1a;Java预备知识 进制转化 &#xff08;1&#xff09;&#xff1a;二进制转十进制采用数字与阶码相乘并相加&#xff0c;阶码从右往左依次增大&#xff0c;从左往右依次减小。 例&#xff1a;100&#xff08;2&#xff09;0*2^00*2^11*2^44(10) (2)&#xff1a…

【远程桌面】远程连接服务器时出现“这可能是由于CredSSP加密数据库修正”的错误提示的解决办法

转发原文&#xff1a;https://blog.csdn.net/juanjuan_01/article/details/127005255 错误提示 Windows10系统中远程连接服务器的时候出现如下错误的提示&#xff1a; 解决方案一&#xff1a; 步骤1、winR打开运行窗口 步骤2、输入gpedit.msc命令&#xff0c;点击“确定”&a…

Go语言-- 版本管理go module以及go.sum详解

为了确保一致性构建&#xff0c;Go语言中引入了go.mod文件来标记每个依赖包的版本&#xff0c;在构建过程中go命令会下载go.mod中的依赖包&#xff0c;下载的依赖包会缓存在本地&#xff0c;以便下次构建。 在进行go语言项目开发的时候&#xff0c;会依赖3种类型的库包&#x…

使用ThreadLocal来存取单线程内的数据

一.什么是ThreadLocal&#xff1f; ThreadLocal&#xff0c;即线程本地变量。如果你创建了一个 ThreadLocal变量&#xff0c;那么访问这个变量的每个线程都会有这个变量的一个本地拷贝&#xff0c;多个线程操作这个变量的时候&#xff0c;实际是在操作自己本地内存里面的变量&…

Selenium+Python自动化测试:解决无法启动IE浏览器及报错问题

&#x1f345; 点击文末小卡片&#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 前言&#xff1a;记录启动IE浏览器的报错及解决方法。 错误1&#xff1a; selenium.common.exceptions.WebDriverException: Message: IEDriverServer.exe execu…

MySQL:索引(Index)语句

索引的限制 每个表最多可以有 16 个索引&#xff08;InnoDB 表的限制&#xff09;。 单个索引最多可以包含 16 列。 索引列的最大长度为 767 字节&#xff08;对于 CHAR, VARCHAR, 和 BINARY 类型&#xff09;&#xff0c;3072 字节&#xff08;对于 BLOB 类型&#xff09;。…

网鼎杯比赛二次注入技巧

文章目录 前端的网页展示分析题目暴力破解寻找代码找到注入点进行注入查询想要的文件 前端的网页展示 分析题目 1.目前我们能看到的只有三个页面&#xff0c;但是我们可以看到三个*号。 2.考虑三个*的密码是什么&#xff0c;这里可以采用暴力破解&#xff08;我们先猜这是三个…

【精选】6款一键生成论文的软件3000字论文网站

千笔-AIPassPaPer是一款功能强大且全面的AI论文写作工具&#xff0c;特别适合学术研究者和学生使用。它不仅能够一键生成高质量的论文初稿&#xff0c;还涵盖了700多个学科专业方向&#xff0c;满足各种学术需求。 一、千笔-AIPassPaPer 传送门&#xff1a;https://www.aipape…

Codeforces Round 963 (Div. 2) A-C

A. Question Marks 直接模拟一遍&#xff0c;&#xff1f;跳过&#xff0c;其他统计 #include<iostream> #include<cstring> #include<string> #include<algorithm> #include<map> using namespace std; int t, n; int w[200005]; int main() …

论文辅导 | 基于概率密度估计与时序Transformer网络的风功率日前区间预测

辅导文章 模型描述 本文所提出的时序优化Transformer 结构&#xff0c;该模型从结构上看由三部分组成&#xff1a;向量映射、编码器和解码器。编码器输入为数值天气预报数据以及相应的时间编码。解码器输入为预测日之前输出功率历史数据以及相应的时间编码。这些数据在经过向量…

【C++高阶】深入理解C++异常处理机制:从try到catch的全面解析

&#x1f4dd;个人主页&#x1f339;&#xff1a;Eternity._ ⏩收录专栏⏪&#xff1a;C “ 登神长阶 ” &#x1f921;往期回顾&#x1f921;&#xff1a;Lambda表达式 &#x1f339;&#x1f339;期待您的关注 &#x1f339;&#x1f339; ❀C异常 &#x1f4d2;1. C异常概念…

MySQL基础:int(1) 和 int(10) 有什么区别

在数据库设计与维护的日常工作中&#xff0c;一个常见但易引发误解的话题围绕着整型字段&#xff08;如INT&#xff09;的显示宽度&#xff08;如int(1)、int(10)&#xff09;的实际作用。这一现象不仅在新手中频繁出现&#xff0c;就连经验丰富的开发者也时常陷入误区。最近&a…

2024年【山东省安全员B证】考试报名及山东省安全员B证证考试

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 山东省安全员B证考试报名参考答案及山东省安全员B证考试试题解析是安全生产模拟考试一点通题库老师及山东省安全员B证操作证已考过的学员汇总&#xff0c;相对有效帮助山东省安全员B证证考试学员顺利通过考试。 1、【…

Linux驱动开发—设备树基本概念,语法详解

文章目录 什么是设备树&#xff0c;为什么引入设备树&#xff1f;设备树基本概念相关术语解释设备树源码所在地使用DTC编译设备树基本的DTC编译命令基本的反编译命令效果演示&#xff08;编译与反编译&#xff09; 设备树语法1. 节点 (Node)2. 属性 (Property)3. 包含文件 (Inc…

uniapp svgIcon组件封装

utils/svg/index.ts 存放处理svg的相关方法 // svg 转成url export function svgToUrl(url: any) {var encoded url.replace(/<!--(.*)-->/g, "").replace(/[\r\n]/g, " ").replace(/"/g, ).replace(/%/g, "%25").replace(/&/…

CSDN 僵尸粉 机器人

CSDN 僵尸粉 机器人 1. 前言 不知道什么时候开始每天创作2篇就有1500流量爆光&#xff0c;每次都能收获一些关注和收藏&#xff0c;感觉还是挻开心的感觉CSDN人气还是挻可以的以前各把月一个收藏和关注都没有写的动力了。 2. 正文 后面又连接做了2天的每日创建2篇任务&…

计算机网络408 2017

https://www.zhihu.com/people/suixinyuan1990 【CN】数据链路层.滑动窗口.GBN协议传输过程信道利用率分析_哔哩哔哩_bilibili okokokok 408考研 计算机网络历年真题 分类汇总和解析—【信道利用率】&#xff08;字幕版&#xff09; 408考研 计算机网络历年真题 分类汇总和…

能见度怎么测?应该用什么仪器测呢?

在气象观测、交通安全以及环境监测等多个领域&#xff0c;能见度的准确测量至关重要。那么&#xff0c;能见度究竟是如何测量的呢&#xff1f;答案就是借助先进的能见度测量仪。 能见度测量仪利用光学原理&#xff0c;通过测量空气中微小颗粒&#xff08;如气体分子、气溶胶粒子…

盐城销量比赛 -- YR Tech团队比赛攻略

关联比赛: [印象盐城]数创未来大数据竞赛 - 乘用车零售量预测 查看更多内容&#xff0c;欢迎访问天池技术圈官方地址&#xff1a;盐城销量比赛 -- YR Tech团队比赛攻略_天池技术圈-阿里云天池

关于进程间通信的练习

1> 使用有名管道实现,一个进程用于给另一个进程发消息,另一个进程收到消息后,展示到终端上,并且将消息保存到文件上 一份 create.c #include<myhead.h>int main(int argc, const char *argv[]) {//创建一个管道文件if(mkfifo("./linux",0664)-1){perror(&qu…