【MySQL】聚合查询 和 分组查询
个人主页:♡喜欢做梦
欢迎 👍点赞 ➕关注 ❤️收藏 💬评论
目录
🌴 一、聚合查询
🌲1.概念
🌲2.聚合查询函数
COUNT()
SUM()
AVG()
MAX()和MIN()
🌴 二、分组查询
🍀1.GROUP BY子句
定义
语法
🍀2.HAVING
定义
having与where的区别
🌴 三、插入查询结果
🍃语法
🌴 一、聚合查询
🌲1.概念
聚合查询:是SQL中对数据进行分组统计的操作,可以将多行数据按照特定条件合并计算,返回汇总结果。
🌲2.聚合查询函数
函数 | 说明 |
COUNT() | 统计行数 |
SUM() | 统计数值列总和 |
AVG() | 统计数值列平均和 |
MAX() | 寻找最大值 |
MIN() | 寻找最小值 |
- 除了函数COUNT(),其他如果不是数字没有意义;
- 除了函数COUNT(),可以进行全列COUNT(*)查询,其他不可以;
- null不参与该查询;
- 多个聚合函数可以同时使用。
示例:
-- 创建学生成绩表
mysql> create table student_grade(-> id bigint auto_increment primary key,-> name varchar(20),-> chinese bigint,-> math bigint,-> english bigint);
Query OK, 0 rows affected (0.07 sec)mysql> insert into student_grade(name,chinese,math,english) values('张三',89,95,65),-> ('李四',96,88,67),('王柿子',78,91,75),('张亮',99,73,97);
Query OK, 4 rows affected (0.13 sec)
Records: 4 Duplicates: 0 Warnings: 0mysql> insert into student_grade(name,chinese,math,english) values('丽丽',null,56,89);
Query OK, 1 row affected (0.05 sec)mysql> select* from student_grade;
+----+-----------+---------+------+---------+
| id | name | chinese | math | english |
+----+-----------+---------+------+---------+
| 1 | 张三 | 89 | 95 | 65 |
| 2 | 李四 | 96 | 88 | 67 |
| 3 | 王柿子 | 78 | 91 | 75 |
| 4 | 张亮 | 99 | 73 | 97 |
| 5 | 丽丽 | NULL | 56 | 89 |
+----+-----------+---------+------+---------+
5 rows in set (0.00 sec)
COUNT()
mysql> select* from student_grade;
+----+-----------+---------+------+---------+
| id | name | chinese | math | english |
+----+-----------+---------+------+---------+
| 1 | 张三 | 89 | 95 | 65 |
| 2 | 李四 | 96 | 88 | 67 |
| 3 | 王柿子 | 78 | 91 | 75 |
| 4 | 张亮 | 99 | 73 | 97 |
| 5 | 丽丽 | NULL | 56 | 89 |
+----+-----------+---------+------+---------+
5 rows in set (0.00 sec)-- 推荐使用COUNT(*)查询
mysql> select count(*) from student_grade;
+----------+
| count(*) |
+----------+
| 5 |
+----------+
1 row in set (0.00 sec)-- 当然,也可以使用常量
mysql> select count(1) from student_grade;
+----------+
| count(1) |
+----------+
| 5 |
+----------+
1 row in set (0.00 sec)-- 可以指定列查询,因为chinese中有null,这不会被统计在内
mysql> select count(chinese) from student_grade;
+----------------+
| count(chinese) |
+----------------+
| 4 |
+----------------+
1 row in set (0.00 sec)
- 一般使用COUNT(*)来查询,里面也可以使用常量,当更推荐使用*;
- 也可以指定列查询;
- 当列中包含null,null不会被统计在内。
SUM()
mysql> select* from student_grade;
+----+-----------+---------+------+---------+
| id | name | chinese | math | english |
+----+-----------+---------+------+---------+
| 1 | 张三 | 89 | 95 | 65 |
| 2 | 李四 | 96 | 88 | 67 |
| 3 | 王柿子 | 78 | 91 | 75 |
| 4 | 张亮 | 99 | 73 | 97 |
| 5 | 丽丽 | NULL | 56 | 89 |
+----+-----------+---------+------+---------+
5 rows in set (0.00 sec)-- 查询数学成绩总和
mysql> select sum(math) from student_grade;
+-----------+
| sum(math) |
+-----------+
| 403 |
+-----------+
1 row in set (0.03 sec)-- 参数可以使用表达式
mysql> select sum(math+chinese+english) as total from student_grade;
+-------+
| total |
+-------+
| 1013 |
+-------+
1 row in set (0.04 sec)-- 查询语文成绩总和
-- 之前说到null与任何值结果相加都为null,chinese有null值但是其结果并不为null
-- 原因:在sum()求和时,null不参与运算
mysql> select sum(chinese) from student_grade;
+--------------+
| sum(chinese) |
+--------------+
| 362 |
+--------------+
1 row in set (0.00 sec)-- *一般用来取所有列,不能直接用在sun()函数里
mysql> select sum(*) from student_grade;
ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '*) from student_grade' at line 1
- *不能直接使用sum()函数里面,一般用于计算某一列中数值的总和,也就是SUM(列名);
- 参数可以使用表达式;
- null不参与SUM()运算。
AVG()
-- 查询语文成绩平均值
mysql> select avg(chinese) from student_grade;
+--------------+
| avg(chinese) |
+--------------+
| 90.5000 |
+--------------+
1 row in set (0.00 sec)-- 查询数学成绩平均值
mysql> select avg(math) from student_grade;
+-----------+
| avg(math) |
+-----------+
| 80.6000 |
+-----------+
1 row in set (0.00 sec)-- 不能使用*
mysql> select avg(*) from student_grade;
ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '*) from student_grade' at line 1
- 其注意事项与SUM()相似
MAX()和MIN()
mysql> select* from student_grade;
+----+-----------+---------+------+---------+
| id | name | chinese | math | english |
+----+-----------+---------+------+---------+
| 1 | 张三 | 89 | 95 | 65 |
| 2 | 李四 | 96 | 88 | 67 |
| 3 | 王柿子 | 78 | 91 | 75 |
| 4 | 张亮 | 99 | 73 | 97 |
| 5 | 丽丽 | NULL | 56 | 89 |
+----+-----------+---------+------+---------+
5 rows in set (0.00 sec)-- 查询数学成绩最大值
mysql> select max(math) from student_grade;
+-----------+
| max(math) |
+-----------+
| 95 |
+-----------+
1 row in set (0.04 sec)-- 查询语文成绩最小值
mysql> select min(chinese) from student_grade;
+--------------+
| min(chinese) |
+--------------+
| 78 |
+--------------+
1 row in set (0.00 sec)-- 可以同时查询
mysql> select max(chinese),min(chinese) from student_grade;
+--------------+--------------+
| max(chinese) | min(chinese) |
+--------------+--------------+
| 99 | 78 |
+--------------+--------------+
1 row in set (0.00 sec)-- 使用别名
mysql> select max(chinese)数学最大值 ,min(chinese)语文最小值 from student_grade;
+-----------------+-----------------+
| 数学最大值 | 语文最小值 |
+-----------------+-----------------+
| 99 | 78 |
+-----------------+-----------------+
1 row in set (0.00 sec)
🌴 二、分组查询
🍀1.GROUP BY子句
定义
定义:GROUP BY是SQL中用于分组聚合的核心子句,用于将查询结果按照一个或多个列的值进行分组,把具有相同列值的行归为一组。找同一组内的数据可以使用聚合函数(如COUNT、SUM、MAX、MIN)。
语法
select column1,sum(conumn2),... from table group by column1,colum3;
- column1:分组的列名;
- sum(column2): 没有被分组的列(需要的运算的列),如果要显示结果,需要用到聚合函数;
- group by:分组查询的关键字;
- column1:要分组的列名。
示例:
统计每个班级的学生数量
-- 创建学生表
mysql> create table students(-> class_id bigint, -- 学生所在班级-> name varchar(20)); -- 学生姓名
Query OK, 0 rows affected (0.04 sec)-- 插入
mysql> insert into students values(1,'杨杨'),(3,'丽丽'),(1,'小美'),(2,'小帅'),(3,'王五');
Query OK, 5 rows affected (0.04 sec)
Records: 5 Duplicates: 0 Warnings: 0-- 查看学生表
mysql> select* from students;
+----------+--------+
| class_id | name |
+----------+--------+
| 1 | 杨杨 |
| 3 | 丽丽 |
| 1 | 小美 |
| 2 | 小帅 |
| 3 | 王五 |
+----------+--------+
5 rows in set (0.00 sec)-- 分组:查看每个班级有多少学生
mysql> select class_id,count(class_id) as student_count from students group by class_id;
+----------+---------------+
| class_id | student_count |
+----------+---------------+
| 1 | 2 |
| 3 | 2 |
| 2 | 1 |
+----------+---------------+
3 rows in set (0.01 sec)-- 将其按班级编号进行升序排序
-- group by后面可以跟order by
mysql> select class_id,count(class_id) as student_count from students group by class_id order by class_id asc;
+----------+---------------+
| class_id | student_count |
+----------+---------------+
| 1 | 2 |
| 2 | 1 |
| 3 | 2 |
+----------+---------------+
3 rows in set (0.00 sec)
🍀2.HAVING
定义
定义:对分组结果进行过滤,group by子句进行分组以后,不能使用where语句,而需要用HAVING。
-- 筛选分组后班级编号小于2的班级
mysql> select class_id,count(class_id) as student_count from students group by class_id having class_id<=2;
+----------+---------------+
| class_id | student_count |
+----------+---------------+
| 1 | 2 |
| 2 | 1 |
+----------+---------------+
2 rows in set (0.00 sec)
- having必须和group by一起用,having要跟在group by后面;
having与where的区别
区别 | where | having |
作用对象 | 分组前对原始数据进行筛选 | 对分组后的结果进行筛选 |
使用限制 | 不能使用聚合函数 | 可以使用聚合函数 |
🌴 三、插入查询结果
插入查询结果:把一个表中的数据插入到另一个表中
🍃语法
insert into table_name [(column1,column2,...)]
select column1,colum2,...
from another_table
- able_name : 被插入数据的表名;
- another_table : 源表,即数据来源的表;
- []:表示可写可不写,如果写了,那么colum1,colum2,...需要加上括号(),并且插入的列数量和数据类型要与被插入的列数量与数据类型相同。
示例:
将旧学生表1中的学生姓名插入到另一个表中
-- 查看旧表学生表1找你中的信息:
mysql> select * from students;
+----------+--------+
| class_id | name |
+----------+--------+
| 1 | 杨杨 |
| 3 | 丽丽 |
| 1 | 小美 |
| 2 | 小帅 |
| 3 | 王五 |
+----------+--------+
5 rows in set (0.02 sec)-- 创建新表
mysql> create table new_student(-> id bigint auto_increment primary key,-> name varchar(20));
Query OK, 0 rows affected (0.09 sec)-- 将旧表中的学生名复制到新表中
mysql> insert into new_student (name) select name from students;
Query OK, 5 rows affected (0.08 sec)
Records: 5 Duplicates: 0 Warnings: 0-- 查看新表中的信息
mysql> select * from new_student;
+----+--------+
| id | name |
+----+--------+
| 1 | 杨杨 |
| 2 | 丽丽 |
| 3 | 小美 |
| 4 | 小帅 |
| 5 | 王五 |
+----+--------+
5 rows in set (0.00 sec)
相关文章:
【MySQL】聚合查询 和 分组查询
个人主页:♡喜欢做梦 欢迎 👍点赞 ➕关注 ❤️收藏 💬评论 目录 🌴 一、聚合查询 🌲1.概念 🌲2.聚合查询函数 COUNT() SUM() AVG(&…...
Weka通过10天的内存指标数据计算内存指标动态阈值
在数据处理和监控系统中,动态阈值的计算是一种常见的方法,用以根据数据的实际分布和变化来调整阈值,从而更有效地监控和预警。在Weka中,虽然它主要是用于机器学习和数据挖掘的工具,但你可以通过一些间接的方法来实现…...
iOS签名的包支持推送功能吗?
推送失败的可能原因: 1. 生产包没有上报token ,所以无法推送成功,需要检查是否在企业包签名后导致无法完成apns的注册,无法从Apple取到token 2. 问题可能出在证书上,因为iOS推送有一个开发证书和一个生产证书ÿ…...
JavaWeb:后端web基础(TomcatServletHTTP)
一、今日内容 二、Tomcat 介绍与使用 介绍 基本使用 小结 配置 配置 查找进程 三、Servlet 什么是Servlet 快速入门 需求 步骤 1.新建工程-模块(Maven) 2.修改打包方式-war 3.编写代码 /*** 可以选择继承HttpServlet*/ WebServlet("/hello&q…...
关于浏览器对于HTML实体编码,urlencode,Unicode解析
目录 HTML实体编码 URL编码 Unicode编码 解析层次逻辑 为什么<script></script>不可以编码符号 为什么不能编码JavaScript:协议 为什么RCDATA标签中的都会被解析成文本 为什么HTML编码了<>无法执行 HTML实体编码 通过特殊语法(<、>…...
C++智能指针滥用带来的性能与内存问题有哪些
在现代C编程中,智能指针(Smart Pointers)已经成为开发者工具箱中不可或缺的一部分。它们作为一种对传统裸指针(Raw Pointers)的替代方案,旨在解决长期困扰C开发者的内存管理难题。C作为一门高性能的系统编程…...
C++算法(17):reverse函数用法详解,头文件<algorithm>与实战示例
在C中,std::reverse 函数用于反转容器或数组中元素的顺序,需包含头文件 <algorithm>。以下是其用法详解: 基本用法 函数原型: template <class BidirIt> void reverse(BidirIt first, BidirIt last); 参数…...
【滑动窗口】最大连续1的个数|将x减到0的最小操作数
文章目录 1.最大连续1的个数2.将x减到0的最小操作数 1.最大连续1的个数 解法: 1.暴力解法给定一个left指针固定左端点元素,再给定一个right指针从左端点元素开始遍历。 当遇到1时,让一个计数器cnt1,当遇到0时,让统计0…...
MySQL 在 CentOS 7 环境下的安装教程
🌟 各位看官好,我是maomi_9526! 🌍 种一棵树最好是十年前,其次是现在! 🚀 今天来学习C语言的相关知识。 👍 如果觉得这篇文章有帮助,欢迎您一键三连,分享给更…...
嵌入式复习第一章
1. 嵌入式系统概念、应用与特点 2. 嵌入式系统的硬件( CPU 、外设) 3. 主要嵌入式软件系统(应用及 OS ) 4. 嵌入式系统的发展趋势 嵌入式系统定义 “以 应用为中心 ,以计算机技术为基础,并且软硬件…...
【C#】.net core6.0无法访问到控制器方法,直接404。由于自己的不仔细,出现个低级错误,这让DeepSeek看出来了,是什么错误呢,来瞧瞧
🌹欢迎来到《小5讲堂》🌹 🌹这是《C#》系列文章,每篇文章将以博主理解的角度展开讲解。🌹 🌹温馨提示:博主能力有限,理解水平有限,若有不对之处望指正!&#…...
Tailwind CSS 实战:基于 Kooboo 构建企业官网页面(三)
基于前两篇内容,继续完善企业官网页面: Tailwind CSS 实战:基于 Kooboo 构建企业官网页面(一)-CSDN博客 Tailwind CSS 实战:基于 Kooboo 构建企业官网页面(二)-CSDN博客 3.5 联系方…...
Opencv中图像深度(Depth)和通道数(Channels)区别
在OpenCV中,图像深度(Depth)和通道数(Channels)是两个完全不同的概念,需严格区分。以下是详细解析: 图像深度(Depth) 定义:指图像中每个像素通道的位数&#…...
【网络原理】从零开始深入理解HTTP的报文格式(一)
本篇博客给大家带来的是网络HTTP协议的知识点, 重点介绍HTTP的报文格式. 🐎文章专栏: JavaEE初阶 🚀若有问题 评论区见 ❤ 欢迎大家点赞 评论 收藏 分享 如果你不知道分享给谁,那就分享给薯条. 你们的支持是我不断创作的动力 . 王子,公主请阅Ὠ…...
Go语言之路————接口、泛型
Go语言之路————接口 前言接口定义实操,接口的定义和实现接口的继承空接口和Any 泛型类型集 结语 前言 我是一名多年Java开发人员,因为工作需要现在要学习go语言,Go语言之路是一个系列,记录着我从0开始接触Go,到后…...
Go语言中的 `time.Tick` 函数详解
time.Tick 是 Go 标准库中用于创建周期性定时器的简便函数。 函数签名 func Tick(d Duration) <-chan Time核心功能 创建一个周期性的定时器通道当 d < 0 时返回 nil返回一个只读的时间通道,定期发送当前时间 与 NewTicker 的关系 time.Tick 是 time.New…...
打印及判断回文数组、打印N阶数组、蛇形矩阵
打印回文数组 1 1 1 1 1 1 2 2 2 1 1 2 3 2 1 1 2 2 2 1 1 1 1 1 1方法1: 对角线对称 左上和右下是对称的。 所以先考虑左上打印, m i n ( i 1 , j 1 ) \text min(i1,j1) min(i1,j1),打印出来: 1 1 1 1 1 2 2 2 1 2 3 3 1 2 …...
【图像融合】基于非负矩阵分解分解 CNMF的高光谱和多光谱数据融合附MATLAB代码
基于CNMF的高光谱与多光谱数据融合技术详解 一、非负矩阵分解(NMF)与约束非负矩阵分解(CNMF)的核心原理 NMF的基本概念 非负矩阵分解(NMF)是一种通过将非负矩阵分解为两个非负矩阵乘积的降维方法。给定非负…...
HarmonyOS NEXT 诗词元服务项目开发上架全流程实战(一、项目介绍及实现效果)
在当今数字化时代,如何让传统文化与现代科技相结合,成为了一个值得思考的问题。诗词作为中国传统文化的重要组成部分,承载着丰富的历史信息和文化内涵。为了让更多人了解和欣赏诗词的魅力,我们决定开发一款基于HarmonyOS NEXT的诗…...
线性代数与数据学习
The Functions of Deep Learning (essay from SIAM News, December 2018) Deep Learning and Neural Nets...
Linux中的计划任务
一次性任务 功能介绍: 如果我们希望在将来的某个时间点去执行某件事件,这个事件执行完后任务就结束,那么我们 就可以使用一性计划任务。而要实现这种功能,我们需要任务 atd 服务。我们先查询一下系 统是否存在这个服务。 查看是…...
【C++】线程池
C 线程池介绍 什么是线程池? 线程池(Thread Pool) 是一种并发编程模型,用于管理和复用多个线程,避免频繁创建/销毁线程的开销。它通过预创建一组线程,并将任务提交到队列中,由空闲线程自动执行…...
美团社招一面
美团社招一面 做题 1、面试题 <style> .outer{width: 100px;background: red;height: 100px; }.inner {width: 50px;height: 50px;background: green; }</style> <div class"outer"><div class"inner"></div> </div>…...
C++:BST、AVL、红黑树
C:BST、AVL、红黑树 二叉搜索树(BST)二叉平衡搜索树(AVL)红黑树(RBT)三者对比什么情况下使用?C 标准库中的使用总结 二叉搜索树(BST) 二叉搜索树(Binary Sea…...
算法笔记.染色法判断二分图
题目:(来自AcWing) 给定一个 n 个点 m 条边的无向图,图中可能存在重边和自环。 请你判断这个图是否是二分图。 输入格式 第一行包含两个整数 n 和 m。 接下来 m 行,每行包含两个整数 u 和 v,表示点 u …...
在 IDEA 中写 Spark 程序:从入门到实践
在大数据处理领域,Apache Spark 凭借其出色的性能和丰富的功能受到广泛欢迎。而 IntelliJ IDEA 作为一款功能强大的 Java 集成开发环境,为编写 Spark 程序提供了极大的便利。本文将详细介绍如何在 IDEA 中搭建 Spark 开发环境并编写运行 Spark 程序&…...
[Spring] Sentinel详解
🌸个人主页:https://blog.csdn.net/2301_80050796?spm1000.2115.3001.5343 🏵️热门专栏: 🧊 Java基本语法(97平均质量分)https://blog.csdn.net/2301_80050796/category_12615970.html?spm1001.2014.3001.5482 🍕 Collection与…...
让数据优雅落地:用 serde::Deserialize 玩转结构体实体
前言 想象一下,服务器突然飞来一堆 JSON 数据,就像一群无头苍蝇冲进办公室,嗡嗡作响,横冲直撞。此刻,你的任务,就是把这群“迷路数据”安置进正确的格子里,分门别类,秩序井然,不混不乱,不漏一只。 好在 Rust 早就为我们备好瑞士军刀:serde::Deserialize。它不仅刀…...
【wpf】 WPF中实现动态加载图片浏览器(边滚动边加载)
WPF中实现动态加载图片浏览器(边滚动边加载) 在做图片浏览器程序时,遇到图片数量巨大的情况(如几百张、上千张),一次性加载所有图片会导致界面卡顿甚至程序崩溃。 本文介绍一种 WPF Prism 实现动态分页加…...
Flow原理
fun main() {runBlocking {launch {flow4.collect{println("---collect-4")}println("---flow4")}}val flow4 flow<Boolean>{delay(5000)emit(false) } 我们分析下整个流程 1.flow为什么之后在collect之后才会发送数据 2.collect的调用流程 我…...
业绩回暖、股价承压,三只松鼠赴港上市能否重构价值锚点?
在营收重返百亿俱乐部后,三只松鼠再度向资本市场发起冲击。 4月25日,这家坚果零食巨头正式向港交所递交上市申请书,若成功登陆港股,将成为国内首个实现“AH”双上市的零食品牌。 其赴港背后的支撑力,显然来自近期披露…...
基于大模型的胆总管结石全流程预测与临床应用研究报告
目录 一、引言 1.1 研究背景 1.2 研究目的与意义 1.3 研究方法和创新点 二、大模型在胆总管结石预测中的应用原理 2.1 大模型概述 2.2 模型构建的数据来源与处理 2.3 模型训练与优化 三、术前预测与准备 3.1 术前胆总管结石存在的预测 3.2 基于预测结果的术前检查方…...
QT—布局管理器之BoxLayout篇
1.布局管理器的概述 在Qt中,使用布局管理器的主要原因是它能够自动管理组件的大小和位置,从而实现灵活且动态的界面布局。布局管理器可以自动调整组件以适应窗口大小的变化,确保界面在不同分辨率和设备上都能保持良好的显示效果。这不仅减少了…...
如何在 IntelliJ IDEA 中编写 Speak 程序
在当今数字化时代,语音交互技术越来越受到开发者的关注。如果你想在 IntelliJ IDEA(一个强大的集成开发环境)中编写一个语音交互(Speak)程序,那么本文将为你提供详细的步骤和指南。 一、环境准备 在开始编…...
湖北理元理律师事务所:债务优化的法律机制与民生实践
在债务纠纷日益增多的社会背景下,合法、规范的债务管理服务成为民生需求的重要环节。湖北理元理律师事务所作为经国家司法局注册登记的债事服务机构,以法律为工具,探索出一套覆盖债务咨询、规划与风险防控的服务体系。 1.法律服务的专业化框…...
练习普通话,说话更有节奏
玲珑塔,塔玲珑,玲珑宝塔第一层,一张高桌四条腿, 一个和尚一本经。一个铙钹一口磬,一个木鱼一盏灯。 一个金玲,整四两,风儿一刮响哗愣。 玲珑塔,隔过两层数三层,三张高桌十…...
链表相关——Python实现
一、链表的创建及数据插入 示例代码: #1.定义一个结点类 class ListNode():def __init__(self,x,nextNone):self.valxself.nextnext #2.定义单链表 class LinkList():#2.1 创建一个头指针为空的链表def __init__(self,headNone):self.headNone#2.2 将数据插入链表…...
[OS_9] C 标准库和实现 | musl libc | offset
在你感觉有困难的时候,计算机 一定有解决办法 操作系统为我们提供了对象和操作它们的 API:我们学习了进程管理的 fork, execve, exit, waitpid;内存管理的 mmap;文件 (对象) 管理的 open, read, write, dup, close, pipe, …… 大…...
【氮化镓】质子辐照对 GaN-on-GaN PiN 二极管电导调制的影响
2025 年,中国科学技术大学的 Xuan Xie 等人采用实验研究的方法,深入探究了 10-MeV 和 50-MeV 质子辐照( fluence 最高达 11014 cm−2)对 kV 级垂直 GaN-on-GaN PiN 二极管的导电调制影响。研究背景在于空间应用中的功率电子电路易受质子、α 粒子和重离子等影响而降级甚至失…...
深入浅出限流算法(一):简单但有“坑”的固定窗口计数器
在现代分布式系统和 API 设计中,限流 (Rate Limiting) 是一个不可或缺的环节。它像一个尽职的门卫,保护着我们的服务资源,防止因突发流量或恶意攻击导致系统过载,同时也能确保资源的公平分配。 实现限流的算法多种多样࿰…...
项目上线流程梳理(Linux宝塔面板)
项目部署(Linux宝塔面板) 一、准备工作 1、 后端项目 梳理配置添加application-prod.yml使用maven进行打包生成jar包 2、前端项目 修改request.ts请求的后端端口(服务器地址)打包 二、服务器 1、服务器环境安装 2、初始化数…...
MCP Servers玩玩WebUI自动化
MCP Servers快速了解 一文搞懂 MCP Servers mcp server网站 https://mcpservers.orghttps://mcp.sohttps://glama.ai/mcp/servershttps://www.pulsemcp.com 一、安装&配置mcp clients mcp clients可以使用客户端(常见claude desktop,但claude需…...
永磁同步电机控制算法-转速环电流环SMC控制器
一、原理介绍 为改进传统PI转速环电流环控制器易超调、抗干扰性能差的问题,转速环采用一阶滑模控制器,电流环采用二阶滑模控制器。 二、仿真验证 在MATLAB/simulink里面验证所提算法,采用和实验中一致的控制周期1e-4,电机部分计…...
Nginx支持HTTP2/HTTP3的并用CURL测试
对比HTTP2和HTTP3 HTTP/3 相比 HTTP/2 的主要优势: 项目HTTP/2HTTP/3传输层基于 TCP( TLS)基于 QUIC(内置 TLS)建立连接速度慢,至少 2~3 次握手(TCP TLS)快,只需 1 次握…...
阅读MySQL实战45讲第11天
目录 引言: 基本原理 排序方式 索引排序 文件排序(File Sort) 优化建议 一、全字段排序 二、rowid 排序 如果 MySQL 认为排序的单行长度太大会怎么做呢? 1. 使用磁盘临时表 2. 分阶段排序 3. 产生警告或错误 三、全字段排序 VS ro…...
linux 使用nginx部署vue、react项目
前言 本文基于:操作系统 CentOS Stream 8 使用工具:Xshell8、Xftp8 1.安装依赖 安装gcc、gcc-c yum install gcc gcc-c -y安装pcre、pcre-devel yum install pcre pcre-devel -y安装zlib、zlib-devel yum install zlib zlib-devel -y安装openssl、…...
逆向设计——CWDM_splitter
一、创建结构 switchtolayout; selectall; delete;## SIM PARAMS num_wg = 4; wg_width = 0.5e-6; out_wg_dist = 1e-6; mode_width = 3*wg_width; total_wg_h = num_wg*wg_width + (num_wg-1)*out_wg_dist;opt_size_x=6e-6; opt_size_y=6e-6;size_x=opt_size_x+1e-6; size_y=o…...
单片机-89C51部分:7、中断
飞书文档https://x509p6c8to.feishu.cn/wiki/A5gcwyL5giq1JOkkcsscn8eLnzf 一、中断的作用 中断是为使单片机具有对外部或内部随机发生的事件实时处理而设置的,中断功能的存在,很大程度上提高了单片机处理外部或内部事件的能力。它也是单片机最重要的功…...
小波变换和图像的融合
看到一篇比较有趣的文章,是将小波变换融入到图像配准过程中。论文题目是Deformable medical image registration based on wavelet transform and linear attention。论文提出了一种基于小波变换和线性注意力的可变形医学图像配准方法,通过小波下采样模块…...
2799. 统计完全子数组的数目
给你一个由 正 整数组成的数组 nums 。 如果数组中的某个子数组满足下述条件,则称之为 完全子数组 : 子数组中 不同 元素的数目等于整个数组不同元素的数目。 返回数组中 完全子数组 的数目。 子数组 是数组中的一个连续非空序列。 示例 1ÿ…...