SpringBoot快速入门笔记(3)

文章目录

  • 一、MybatisPlus
    • 1、ORM
    • 2、添加依赖
    • 3、全局配置
    • 4、Navicat
    • 5、UserController
    • 6、CRUD操作
    • 7、BaseMapper
    • 8、两个注解
  • 二、多表查询
    • 1、模拟用户订单
    • 2、通过用户查相关订单
    • 3、UserMapperNew
    • 4、查询订单和所属用户
    • 5、OrderMapper
    • 6、OrderController
  • 三、条件查询
  • 四、分页查询

一、MybatisPlus

1、ORM

(Object Relational Mapping)对象关系映射,为了解决面向对象与关系数据库存在的互不匹配的一种技术

ORM框架本质是简化编程中操作数据库的编码

2、添加依赖

<!--        MyBatisPlus依赖--><dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.4.2</version></dependency>
<!--        mysql驱动依赖--><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>5.1.32</version></dependency>
<!--        数据连接池druid--><dependency><groupId>com.alibaba</groupId><artifactId>druid</artifactId><version>1.1.23</version></dependency>

3、全局配置

在application.properties中添加配置

server.port=80
spring.datasource.type=com.alibaba.druid.pool.DruidDataSource
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3307/demo2?useSSL=false
spring.datasource.username=root
spring.datasource.password=123456
mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl

😮由于我PC有两个数据库版本的存在,所以这里使用3307端口不产生冲突,数据库的名称为demo2,账号密码默认

在启动项,也就是项目名Application中添加@MapperScan注解,这里是新建的mapper包,如果不好找路径,那么鼠标右键点击包,选择Copy Path/Reference...复制路径
在这里插入图片描述

4、Navicat

在navicat里面把表建好,然后选择id主键自增
在这里插入图片描述

5、UserController

这里模拟查询用户

之前的实体类User继续使用

这里是引用

编写UserMapper接口:

这里是引用

编写UserController,并且声明UserMapper对象,写上@AutoWired注解表示注入,这样我们可以直接使用UserMapper中的方法🤓

在这里插入图片描述

🌐浏览器测试一下:

这里是引用

😈如果查询不到报错:检查数据库是否正常连接
也可以在控制台日志看到结果:

这里是引用

6、CRUD操作

同理,有查就少不了指定id查、增删改

查询指定用户:

UserController:这里是引用
UserMapper:
在这里插入图片描述

增删改UserController:

这里是引用
在这里插入图片描述
在这里插入图片描述

增删改UserMapper:

这里是引用

🌍打开ApiPost测试一下:

这里是引用
在这里插入图片描述

这里id是8虽然是自增,因为我之前测试过几条,我们可以再加一条:

这里是引用
在这里插入图片描述

可以看到表更新了😀

😈如果表中的username是???说明是编码的问题,在navicat中设置utf-8字符集还没用的话,继续在application.properties中的url后多加点规则

spring.datasource.url=jdbc:mysql://localhost:3307/demo2?useSSL=false&useUnicode=true&characterEncoding=utf-8

😈如果出现Data truncated for column id at row 1问题,①检查实体类参数类型是否和数据库表中匹配
②将数据库表的int范围调高
③看看是不是id默认在表里面排最后了,把id上移到第一条和mapper中语句参数对应😲

7、BaseMapper

白学时刻,以上都是我们在mybatis中用到的,而mybatisPlus提供了BaseMapper接口

新建UserMapperNew接口:

这里是引用

修改UserController类,可以发现userMapperNew里面就自带了很多方法,可以ctrl+左键点进去详情查看:

这里是引用

List<User> list = userMapperNew.selectList(null);

重新测试一下 🤓

这里是引用

剩下方法类似👍

8、两个注解

@TableName注解说明了对应哪一张表,应对实体类和表不一致
@TableId主键自增,在控制台打印日志时看到对应的id(之前会显示0)

在这里插入图片描述

二、多表查询

实现复杂关系映射,可以使用@Results、@Result、@One、@Many注解组合完成复杂关系的配置

1、模拟用户订单

navicat 新建订单order表(uid表示所属哪个用户订单):
在这里插入图片描述

2、通过用户查相关订单

在User类里添加代码,其实orders这个东西是不在user表里的,所以这样打上注解,并且添加getter和setter方法,只是为了实现多表查询😮

在这里插入图片描述

在UserMapperNew中定义查找用户和订单的接口:

这里是引用

在UsrController中调用:

这里是引用

🌍浏览器访问,发现orders为空(因为本来user表中就没有orders)

这里是引用

3、UserMapperNew

利用@Results、@Result和@Many注解

 //查询用户及其所有的订单@Select("select * from user")@Results({@Result(column = "id",property = "id"),@Result(column = "username",property = "username"),@Result(column = "password",property = "password"),@Result(column = "birthday",property = "birthday"),@Result(column = "id",property = "orders",javaType = List.class,many=@Many(select = "com.example.demo.mapper.OrderMapper.selectByUid"))})List<User> selectAllUserAndOrders();

这里是将结果集对应起来,然后利用user表中的id,去映射orders,说明orders的参数类型List,many表示一对多的关系;UserMapperNew去使用OrderMapper中的方法😮使得user表的id能够作为order表的uid去执行sql语句

这里是引用

😈刚开始我报错说是语法问题,检查后无误,又将包全部导入一遍,还是爆500错误;发现可能是关键字冲突,将order表的名字改为t_order后成功运行

这里是引用

4、查询订单和所属用户

同理,在Order实体类加上注解,说明user参数并不存在

 @TableField(exist = false)private User user;

5、OrderMapper

//    查询所有的订单,同时查询订单所属的用户@Select("select * from t_order")@Results({@Result(column = "id",property = "id"),@Result(column = "orderTime",property = "orderTime"),@Result(column = "money",property = "money"),@Result(column = "uid",property = "uid"),@Result(column = "uid",property = "user",javaType = User.class,one=@One(select = "com.example.demo.mapper.UserMapperNew.selectById"))})List<Order> selectAllOrdersAndUser();

这里是一个订单只对应一个用户,所以是@One注解,利用订单的uid对应找出user表中的用户

6、OrderController

新建OrderController控制器,运行

@RestController
public class OrderController {@AutowiredOrderMapper orderMapper;@GetMapping("/order/findAll")public List<Order> find(){return orderMapper.selectAllOrdersAndUser();}
}

这里是引用

可以看到三个订单以及所属的用户都被查询出来了 🤓

三、条件查询

前面说过MybatisPlus对单表查询增强了,我们可以不用自己写sql语句,这里采用QueryWrapper

UserController,表示我们只想找到关于火男的信息:

//    条件查询@GetMapping("/user/find")public List<User> findByCondition(){QueryWrapper<User> queryWrapper = new QueryWrapper();queryWrapper.eq("username","火男");return userMapperNew.selectList(queryWrapper);}

这里是引用

四、分页查询

UserController:

//    分页查询@GetMapping("/user/findByPage")public IPage findByPage(){
//        设置起始值和每页条数Page<User> page = new Page<>(0, 2);IPage iPage = userMapperNew.selectPage(page,null);return iPage;}

可以在mybatis-plus官网查看page使用方法:

这里是引用

edge运行结果默认返回JSON格式,如果其他的浏览器可以用F12查看具体参数:

这里是引用

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

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

相关文章

【Ubuntu】用 VMware 安装 macOS

本教程使用 Ubuntu 20.04.6 LTS&#xff0c;VMware Workstation Pro 17.5.1&#xff0c;macOS Sonoma 14.4。文中所有需要的下载链接均以 Markdown 的形式体现在文字上。 下载 VMware Workstation Pro&#xff0c;目前最新版本是 17.5.1。 使用密钥&#xff0c;进行破解。 VM…

金融中的数学知识

随机偏微分方程相比普通偏微分方程具有额外的随机项&#xff0c;反映了其描述的现象具有随机性质

【核弹级安全事件】XZ Utils库中发现秘密后门,影响主要Linux发行版,软件供应链安全大事件

Red Hat 发布了一份“紧急安全警报”&#xff0c;警告称两款流行的数据压缩库XZ Utils&#xff08;先前称为LZMA Utils&#xff09;的两个版本已被植入恶意代码后门&#xff0c;这些代码旨在允许未授权的远程访问。 此次软件供应链攻击被追踪为CVE-2024-3094&#xff0c;其CVS…

中国大学生计算机设计大赛—软件应用与开发赛道—赛后感想

1.比赛介绍 中国大学生计算机设计大赛是我国高校面向本科生最早的赛事之一&#xff0c;是全国普通高校大学生竞赛排行榜榜单赛事之一。自2008年开赛至2019年&#xff0c;一直由教育部高校与计算机相关教指委等或独立或联合主办。大赛的目的是以赛促学、以赛促教、以赛促创&…

一些题目学习

1.打开文件添加helloworld public class Saier {public static void main(String[] args){String path"C:\\Users\\sjg\\Desktop\\abc.txt";String text"hello world";try {File file new File(path);FileWriter fileWriter new FileWriter(file,true);…

阴影画图转html

深受启发 https://segmentfault.com/a/1190000014943400?utm_sourcetag-newest https://gitee.com/yun-36/shadow-drawing 通过File对象&#xff0c;读成dataURL&#xff0c;生成图片&#xff0c;挂到canvas&#xff0c;生成图片文件对应的rgba数据像素点信息&#xff0c;处理…

ideaSSM 校园兼职招聘平台bootstrap开发mysql数据库web结构java编程计算机网页源码maven项目

一、源码特点 idea 开发 SSM 校园兼职招聘平台是一套完善的信息管理系统&#xff0c;结合SSM框架和bootstrap完成本系统&#xff0c;对理解JSP java编程开发语言有帮助系统采用SSM框架&#xff08;MVC模式开发&#xff09;&#xff0c;系统具有完整的源代码和数据库&#xff…

探索设计模式的魅力:揭秘B/S模式在AI大模型时代的蜕变与进化

​&#x1f308; 个人主页&#xff1a;danci_ &#x1f525; 系列专栏&#xff1a;《设计模式》《MYSQL应用》 &#x1f4aa;&#x1f3fb; 制定明确可量化的目标&#xff0c;坚持默默的做事。 &#x1f680; 转载自热榜文章&#xff1a;探索设计模式的魅力&#xff1a;揭秘B/S…

小波降噪基础-python版本

这篇小文将使用小波多分辨分析对一个简单信号进行降噪&#xff0c;主要是降噪流程&#xff0c;为以后的小波更复杂的降噪算法打下良好的基础。降噪算法流程大致如下&#xff1a; &#xff08;1&#xff09;去趋势项&#xff08;如直流电流&#xff09;&#xff0c;并将数据归一…

不能在主机和虚拟机之间拷贝文本(虚拟机ubuntu16.04)

问题 ubuntu16.04不能在主机和虚拟机之间拷贝文本。 原因 vmware tools没安装好。 解决办法 重新安装vmware tools&#xff0c;步骤入下&#xff1a; 让虚拟机加载C:\Program Files (x86)\VMware\VMware Workstation\linux.iso光盘文件&#xff0c;设置如下&#xff1a; …

代码随想录算法训练营第30天|LeetCode236.二叉树的最小公共祖先

代码随想录算法训练营第30天|LeetCode236.二叉树的最小公共祖先 1、LeetCode236.二叉树的最小公共祖先 236. 二叉树的最近公共祖先 - 力扣&#xff08;LeetCode&#xff09; 自底向上查找&#xff0c;有点难度&#xff01; | LeetCode&#xff1a;236. 二叉树的最近公共祖先_哔…

layui框架实战案例(26):layui-carousel轮播组件添加多个Echarts图标的效果

在Layui中&#xff0c;使用layui-carousel轮播组件嵌套Echarts图表来实现多个图表的展示。 css层叠样式表 调整轮播图背景色为白色&#xff1b;调整当个Echarts图表显示loading…状态&#xff1b;同一个DIV轮播项目添加多个Echarts的 .layui-carousel {background-color: #f…

Redis 缓存雪崩、穿透、击穿、预热

在实际工程中&#xff0c;Redis 缓存问题常伴随高并发场景出现。例如&#xff0c;电商大促、活动报名、突发新闻时&#xff0c;由于缓存失效导致大量请求访问数据库&#xff0c;导致雪崩、击穿、穿透等问题。因此&#xff0c;新系统上线前需预热缓存&#xff0c;以应对高并发&a…

文献阅读:将条形码神经解剖学与空间转录分析相结合,可以识别投射神经元相关基因

文献介绍 「文献题目」 Integrating barcoded neuroanatomy with spatial transcriptional profiling enables identification of gene correlates of projections 「研究团队」 Anthony M. Zador&#xff08;美国冷泉港实验室&#xff09; 「发表时间」 2021-05-10 「发表期…

# #一眼就解密

BUUCTF #一眼就解密 1 下面的字符串解密后便能获得flag&#xff1a;ZmxhZ3tUSEVfRkxBR19PRl9USElTX1NUUklOR30 注意&#xff1a;得到的 flag 请包上 flag{} 提交 flag{THE_FLAG_OF_THIS_STRING}

MPLS-基础、LSR、LSP、标签、体系结构

MPLS技术 MPLS基础 MPLS&#xff1a;转发数据时&#xff0c;只在网络边缘分析IP报文头&#xff0c;不在每一跳都分析&#xff0c;节约了转发时间。 MPLS&#xff1a;Multiprotocol Label Switching&#xff0c;多协议标签交换骨干网技术。主要应用&#xff1a;VPN、流量工程…

Golang学习系列1-pprof性能调优

1. pprof 简述 一位亦师亦友的话让我记忆犹新&#xff0c;他说“学习一个新事务&#xff0c;应该从三个方面入手what,why,how;且三者的重要程度应该是递减”。所以在本文的第一部分先叙述下pprof的what & why。 1.1 What&#xff1f; pprof是golang自身提供的一种性能分…

【C++入门】初识C++

&#x1f49e;&#x1f49e; 前言 hello hello~ &#xff0c;这里是大耳朵土土垚~&#x1f496;&#x1f496; &#xff0c;欢迎大家点赞&#x1f973;&#x1f973;关注&#x1f4a5;&#x1f4a5;收藏&#x1f339;&#x1f339;&#x1f339; &#x1f4a5;个人主页&#x…

稀疏矩阵的三元组表表示法及其转置

1. 什么是稀疏矩阵 稀疏矩阵是指矩阵中大多数元素为零的矩阵。 从直观上讲&#xff0c;当元素个数低于总元素的30%时&#xff0c;这样的矩阵被称为稀疏矩阵。 由于该种矩阵的特点&#xff0c;我们在存储这种矩阵时&#xff0c;如果直接采用二维数组&#xff0c;就会十分浪费…

开启 Keep-Alive 可能会导致http 请求偶发失败

大家好&#xff0c;我是蓝胖子&#xff0c;说起提高http的传输效率&#xff0c;很多人会开启http的Keep-Alive选项&#xff0c;这会http请求能够复用tcp连接&#xff0c;节省了握手的开销。但开启Keep-Alive真的没有问题吗&#xff1f;我们来细细分析下。 最大空闲时间造成请求…