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.hqwc.cn/news/593483.html

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

相关文章

非关系型数据库-----------探索Redis支持五种数据类型

目录 一、Redis支持五种数据类型 1.String&#xff08;字符串&#xff09; 2.Hash&#xff08;哈希&#xff09; 3.List&#xff08;列表&#xff09; 4.Set&#xff08;集合&#xff09; 5.sorted set(有序集合) 二、Redis的字符串类型string 1、 SET/GET/APPEND/STRL…

Advanced RAG 01:讨论未经优化的 RAG 系统存在的问题与挑战

编者按&#xff1a; 自 2023 年以来&#xff0c;RAG 已成为基于 LLM 的人工智能系统中应用最为广泛的架构之一。由于诸多产品的关键功能严重依赖RAG&#xff0c;优化其性能、提高检索效率和准确性迫在眉睫&#xff0c;成为当前 RAG 相关研究的核心问题。 我们今天为大家带来的这…

齐护机器人方位传感器指南针罗盘陀螺仪

一、方位传感器原理及功能说明 齐护方位传感器是一款集成了三轴磁传感器芯片的方位传感器模块。适用于无人机、机器人、移动和个人手持设备中的罗盘&#xff08;指南针&#xff09;、导航和游戏等高精度应用。模块可以感应XYZ平面角度外&#xff0c;还可实现1至2的水平面角度罗…

基于springboot+vue+Mysql的大学生租房系统

开发语言&#xff1a;Java框架&#xff1a;springbootJDK版本&#xff1a;JDK1.8服务器&#xff1a;tomcat7数据库&#xff1a;mysql 5.7&#xff08;一定要5.7版本&#xff09;数据库工具&#xff1a;Navicat11开发软件&#xff1a;eclipse/myeclipse/ideaMaven包&#xff1a;…

目标追踪StrongSORT——基于DeepSORT重大升级提高多目标跟踪的准确性和鲁棒性

1、概述 1.1 DeepSORT DeepSORT算法是在SORT基础上发展起来的一种多目标跟踪算法。SORT算法结合了目标检测器和跟踪器&#xff0c;其中跟踪器的核心是卡尔曼滤波和匈牙利算法。卡尔曼滤波用于预测目标在下一帧的位置和状态&#xff0c;而匈牙利算法则用于将预测状态与实际检测…

vue 视频添加水印

1.需求背景 其实腾讯云点播的api也支持视频水印&#xff0c;但是只有单个水印&#xff0c;大概效果是这样子的&#xff0c;不满足我们的需求&#xff0c;我们的需求是需要视频中都是水印。 腾讯云点播水印 项目需求的水印&#xff08;主要是防录屏,最后的实现效果是这样&…

APK安装包与系统不兼容 请尝试安装与当前系统兼容的安装包 SDK编译版本低

安装一些低版本SDK编译或者老版本的软件时提醒无法安装但是又想要使用&#xff0c;这种情况下也能安装。 系统安装包管理器的提示 两种解决方案 第一种无需 Root 通过 ADB 给 Shizuku 授权&#xff0c; 打开 Shizuku 再授权 MT 文件管理器直接安装或者其他安装包管理器安装…

考研人千万不能犯的错误——什么情况下求极限可以直接带入值?

博主最近在复习考研的过程中&#xff0c;做了武忠祥老师的每日一题发现有一个题型错的很集中&#xff0c;就是关于极限数值带入的问题&#xff0c;相信也有不少的宝子容易在这种题型上犯错&#xff0c;今天带大家梳理总结一下常见的计算极限时容易犯的错误 极限的四则运算定义…

Prometheus+grafana环境搭建MongoDB(docker+二进制两种方式安装)(五)

由于所有组件写一篇幅过长&#xff0c;所以每个组件分一篇方便查看&#xff0c;前四篇mongodb的exporter坑也挺多总结一下各种安装方式&#xff0c;方便后续考古。 Prometheusgrafana环境搭建方法及流程两种方式(docker和源码包)(一)-CSDN博客 Prometheusgrafana环境搭建rabb…

Flutter仿Boss-4.短信验证码界面

效果 简述 在移动应用开发中&#xff0c;处理短信验证码是确保用户身份验证和安全性的重要步骤。本文将介绍如何使用Flutter构建一个短信验证码界面&#xff0c;让用户输入通过短信发送到他们手机的四位验证码。 依赖项 在这个项目中&#xff0c;我们将使用以下依赖项&#…

4.4C++

1 #include <iostream> #include <cmath> using namespace std; class A{ private:int a;// 判断一个数是否为质数bool isP(int num) {if (num<2) return false;for (int i2;i<sqrt(num);i) {if (num % i 0) {return false;}}return true;} public:// 构造…

QT----opencv4.8.0编译cuda版本,QTcreater使用

目录 1 编译opencv4.8.02 验证能否加载GPU cuda12.1 opencv4.8.0 vs2019 cmake3.29 1 编译opencv4.8.0 打开cmake&#xff0c;选择opencv480路径&#xff0c;build路径随意 点击configure后&#xff0c;选择这些选项&#xff0c;opencv_word&#xff0c;cuda全选&#xff0c;…