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.rhkb.cn/news/296924.html

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

相关文章

Java中生成一个唯一的文件名的方法

使用java.util.UUID&#xff08;通用唯一识别码&#xff09;的randomUUID()方法&#xff1a; import java.util.UUID;public class Test {public static void main(String[] args) {for (int i 0; i < 100; i) {String fileName UUID.randomUUID().toString();System.out…

element-ui card 组件源码分享

今日简单分享 card 组件源码&#xff0c;主要从以下两个方面&#xff1a; 一、card 组件页面结构 二、card 组件属性 2.1 header 属性&#xff0c;设置 header&#xff0c;也可以通过 slot#header 传入 DOM&#xff0c;类型 string&#xff0c;无默认值。 组件使用部分&#…

04 | Swoole 源码分析之 epoll 多路复用模块

首发原文链接&#xff1a;Swoole 源码分析之 epoll 多路复用模块 大家好&#xff0c;我是码农先森。 引言 在传统的IO模型中&#xff0c;每个IO操作都需要创建一个单独的线程或进程来处理&#xff0c;这样的操作会导致系统资源的大量消耗和管理开销。 而IO多路复用技术通过…

Redis的5大常见数据类型的用法

上一篇文章我们讲了Redis的10大应用场景&#xff0c;这一篇文章就针对Redis的常用数据结构进行一个说明&#xff0c;通过示例的形式演示每一种数据结构如何使用。 当涉及Redis的数据操作时&#xff0c;不同数据类型对应的不同数据结构&#xff0c;如下就对5大常用的数据类型进行…

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

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

数据结构—树

树概述 树类似于现实生活中倒置的树。任何一颗非空树只有一个根节点。一棵树具有以下特点&#xff1a; 一棵树中的任意两个结点有且仅有唯一的一条路径连通。一棵树如果有 n 个结点&#xff0c;那么它一定恰好有 n-1 条边。一棵树不包含回路。 下图就是一颗树&#xff0c;并…

ALPHA开发板上的PHY芯片驱动:LAN8720驱动

一. 简介 前面文章了解到&#xff0c;Linux内核是有提供 PHY通用驱动的。 本文来简单了解一下ALPHA开发板上的 PHY网络芯片LAN8720的驱动。是 LAN8720芯片的公司提供的 PHY驱动。 二. ALPHA开发板上的PHY芯片驱动&#xff1a;LAN8720驱动 我 们 来 看 一 下 LAN8720A 的 …

大模型量化技术-GPTQ

大模型量化技术-GPTQ 2022年,Frantar等人发表了论文 GPTQ:Accurate Post-Training Quantization for Generative Pre-trained Transformers。 这篇论文详细介绍了一种训练后量化算法,适用于所有通用的预训练 Transformer模型,同时只有微小的性能下降。 GPTQ算法需要通过…

【随笔】Git 基础篇 -- 分支与合并 git rebase(十)

&#x1f48c; 所属专栏&#xff1a;【Git】 &#x1f600; 作  者&#xff1a;我是夜阑的狗&#x1f436; &#x1f680; 个人简介&#xff1a;一个正在努力学技术的CV工程师&#xff0c;专注基础和实战分享 &#xff0c;欢迎咨询&#xff01; &#x1f496; 欢迎大…

Linux提权!!!

上一篇文章讲了Windows的提权&#xff0c;那么这篇文章就来讲一下Linux的提权 1.SUID提权 suid权限 作用&#xff1a;让普通用户临时拥有该文件的属主的执行权限&#xff0c;suid权限只能应用在二进制可执行文件&#xff08;命令&#xff09;上&#xff0c;而且suid权限只能设置…

Vue依赖注入,详细解析

Prop 逐级透传问题​ 通常情况下&#xff0c;当我们需要从父组件向子组件传递数据时&#xff0c;会使用 props。想象一下这样的结构&#xff1a;有一些多层级嵌套的组件&#xff0c;形成了一颗巨大的组件树&#xff0c;而某个深层的子组件需要一个较远的祖先组件中的部分数据。…

优先队列c++

内容&#xff1a; priority_quene是一个优先队列&#xff0c;优先级别高的先入队&#xff0c;默认最大值优先 因此出队和入队的时间复杂度均为O&#xff08;logn&#xff09;,也可以自定义优先级 头文件<quene> 函数&#xff1a; 构建优先队列 priority_queue<in…

Pycharm+Neo4j红楼梦人物关系图谱

欢迎来到我的主页~【蜡笔小新..】 本篇收录于专栏【Python】 如果对你有帮助&#xff0c;希望点赞收藏加关注啦~ 目录 前言 neo4j基础知识 Pycharm及代码实现 py2neo 数据集获取 代码介绍 前言 Python实验课时&#xff0c;老师提到用知识图谱构建红楼梦的人物关系图&…

Vue.js基础指令

(在讲指令之前,可以先了解插值表达式,如果已经知道,当我没说) 一.插值表达式 1.数据绑定最常见的形式就是双大括号的文本插值,Mustache上属性的值替代。只要绑定的数据对象上属性发生了改变,插值处的内容都会更新。,message 是将数据解析成纯文本的,也就是说,就算中…

Linux之进程间通信

1.进程间通信的目的 数据传输&#xff1a;一个进程需要将它的数据发送给另一个进程 资源共享&#xff1a;多个进程之间共享同样的资源。 通知事件&#xff1a;一个进程需要向另一个或一组进程发送消息&#xff0c;通知它&#xff08;它们&#xff09;发生了某种事件&#xff…

FressRTOS_day4:2024/4/4

1.总结二进制信号量和计数型信号量的区别&#xff0c;以及他们的使用场景。 二进制信号量的数值只有0和1。&#xff08;用于共享资源的访问&#xff09;&#xff1b;而计数型信号量的值一般是大于或者等于2&#xff08;用于生产者和消费者模型&#xff09; 2.使用计数型信号量…

【linux】进程替换的应用|shell解释器的实现

当我们学过了进程替换之后&#xff0c;本篇文章可以根据进程替换的知识带你自主实现一个shell命令行 实现步骤 1.显示命令行提示 2.读取输入指令以及对应选项 3.分割第二步的指令以及选项到命令行参数表中 4.处理内建命令 5.进程替换 1.显示命令行提示 我们通过观察bash的命令行…

计算机网络:局域网的数据链路层

✨✨ 欢迎大家来访Srlua的博文&#xff08;づ&#xffe3;3&#xffe3;&#xff09;づ╭❤&#xff5e;✨✨ &#x1f31f;&#x1f31f; 欢迎各位亲爱的读者&#xff0c;感谢你们抽出宝贵的时间来阅读我的文章。 我是Srlua小谢&#xff0c;在这里我会分享我的知识和经验。&am…

Java基础 - 代码练习

第一题&#xff1a;集合的运用&#xff08;幸存者&#xff09; public class demo1 {public static void main(String[] args) {ArrayList<Integer> array new ArrayList<>(); //一百个囚犯存放在array集合中Random r new Random();for (int i 0; i < 100; …

红黑树的性质与操作:吸收红结点及其对树结构的影响

红黑树的性质与操作&#xff1a;吸收红结点及其对树结构的影响 1.红黑树的基本性质2.吸收红结点的过程2.1黑色结点的度2.2 叶结点深度 3.伪代码实现4. C语言代码实现5. 结论 红黑树作为一种高效的自平衡二叉搜索树&#xff0c;在计算机科学中扮演着重要的角色。它通过一系列复杂…