sql专题 之 常用命令

文章目录

  • 查询
    • 基础语法
      • 查询
        • 全表查询
        • 选择查询:
        • 常量和运算:
      • 条件查询
        • where
        • 运算符:=、 !=、<、>
        • 空值:null
        • 模糊查询:like
        • 逻辑运算:and or not
      • 去重:distinct
      • 排序:order by
      • 截断和偏移:limit offset
      • 条件分支:case when then end
    • 函数
      • 查询奇偶
      • 时间函数
      • 字符串处理
      • 聚合函数:sum、avg、count、max、min
    • 分组聚合
      • 单字段分组:group by
      • 多字段分组
      • having子句
    • 查询进阶
      • 关联查询
        • cross join
        • inner join ... on
        • outer join ... on:left join 和 right join
      • 子查询
        • 嵌套查询
        • exists
      • 组合查询
      • 开窗函数
        • sum over(partition by ...)
        • sum over by order by
        • rank() over(partition by ... order by ...)
        • row_number()
        • lag & lead
  • 添加
  • 修改
  • 删除

查询

我们先来常见一个student表,表中的字段及数据如下图:
在这里插入图片描述

基础语法

查询

全表查询
# 查询student表的所有信息
select * from student
选择查询:
# 选取所有学生的姓名(name)和年龄(age)信息,并为它们取别名为 学生姓名 和 学生年龄。
select name as 学生姓名,age as 学生年龄 from student
常量和运算:
# 查询student的数据表中所有学生的姓名(name)和分数(score),并且额外计算出分数的 2 倍(double_score)
select name,score,score*2 as double_score from student

条件查询

where

使用where子句在查询中设置过滤条件,只有满足条件的数据行才会被返回。

# 从student 表中选择出所有学生的姓名(name)和成绩(score),要求学生姓名为 '韩梅梅'
select name,score from student where name='韩梅梅'
运算符:=、 !=、<、>

SQL 中用于在条件查询中进行条件判断的特殊符号,如 =、 !=、<、> 等均为运算符

# 从student 的表中选择出所有学生的姓名(name)和年龄(age),要求学生姓名不等于 '韩梅梅' 
select name,age from student where name!='韩梅梅'
空值:null

在数据库中,有时候数据表的某些字段可能没有值,即为空值(NULL)。
空值表示该字段的值是未知的、不存在的或者没有被填写的。
在SQL查询中,我们可以使用 “IS NULL” 和 “IS NOT NULL” 来判断字段是否为空值或非空值

# 从student 的表中选择出所有学生的姓名(name)、年龄(age)和成绩(score),要求学生年龄不为空值
select name,age,score from student where age is not null
模糊查询:like

模糊查询使用的是like关键字,结合通配符来代表0个或多个字符,从而快速的查询到需要的数据。
百分号[%]:表示任意长度的任意字符序列
下划线[_]:表示任意单个字符

# 从student 表中选择出所有学生的姓名(name)和成绩(score),要求姓名(name)不包含 "李" 这个字
select name,score from student where name not like '%李%'
# 从student 表中选择出所有学生的姓名(name)和成绩(score),要求姓名(name)第二个子为"云" 
select name,score from student where name like '_云%'
逻辑运算:and or not

逻辑运算允许我们结合多个条件来过滤出符合特定条件的数据。
常用的运算符有:
and:表示逻辑与,要求同时满足多个条件,才返回 true。
or:表示逻辑或,要求满足其中任意一个条件,就返回 true。
not:表示逻辑非,用于否定一个条件(本来是 true,用了 not 后转为 false)

#  从 student 表中选择出所有学生的姓名(name)、成绩(score),要求学生的姓名包含 "李",或者成绩(score)大于 500。
select name,score from student 
where name like '%李%' or score>500

去重:distinct

针对数据表中重复的数据记录,我们可以使用 DISTINCT 关键字来实现去重操作。

# 从名为 student 的数据表中选择出所有不重复的班级 ID(class_id)和考试编号(exam_num)的组合。
select distinct class_id,exam_num from student

排序:order by

在 SQL 中,我们可以使用 ORDER BY 关键字来实现将结果按照某个字段的值进行排序。
关键字是:order by + 排序字段
可以选择升序(asc)或降序(desc)排列。默认是升序

# 从名为 student 的数据表中选择出学生姓名(name)、年龄(age)和成绩(score),首先按照成绩从大到小排序,如果成绩相同,则按照年龄从小到大排序。
select name,age,score from student
order by score desc,age

截断和偏移:limit offset

只想查看部分数据时,我们使用 limit 关键字来实现数据的截断和偏移。
limit 后只跟一个整数,表示要截断的数据条数(一次获取几条)
limit 后跟 2 个整数,依次表示从第几条数据开始、一次获取几条

# 从名为 student 的数据表中选择学生姓名(name)和年龄(age),按照年龄从小到大排序,从第 2 条数据开始、截取 3 个学生的信息。
select name,age from student order by age limit 3 offset 1
select name,age from student order by age limit 1,3

如果使用offset则表示跳过的内容,即 limit 1,3 等同于 limit 3 offset 1

条件分支:case when then end

case when 可以在查询结果中根据特定的条件动态生成新的列或对现有的列进行转换
示例语法:
case when (条件1) then 结果1
when (条件2) then 结果2

else 其他结果 end

# 将学生按照年龄划分为三个年龄等级(age_level):60 岁以上为 "老同学",20 岁以上(不包括 60 岁以上)为 "年轻",20 岁及以下、以及没有年龄信息为 "小同学"。返回结果应包含学生的姓名(name)和年龄等级(age_level),并按姓名升序排序
select name,
case when(age>60) then '老同学' when(age>20) then '年轻' else'小同学' end as age_level 
from student
order by name
  • 来力扣做个小练习吧 :610. 判断三角形

函数

查询奇偶

一般用于筛选某列的数值为奇数或者偶数,可以使用mod函数,也可以使用where条件筛选

# 展示所有学生id为奇数的学生的姓名(name)
select name
from student
where id%2=1
# 展示所有学生id为奇数的学生的姓名(name)
select name
from student
where mod(id,2)=1

时间函数

常用的时间函数有:
DATE:获取当前日期
DATETIME:获取当前日期时间
TIME:获取当前时间

获取当前日期:SELECT DATE() AS current_date;
获取当前日期时间:SELECT DATETIME() AS current_datetime;
获取当前时间:SELECT TIME() AS current_time;

# 展示所有学生的姓名(name)和当前日期(列名为 "当前日期")
select name,Date() as 当前日期
from student

字符串处理

使用函数 UPPER 将数据转换为大写
使用字符串处理函数 LENGTH 计算长度
使用函数 LOWER 将数据转换为小写

# 筛选出姓名为 '热dog' 的学生,展示其学号(id)、姓名(name)及其大写姓名(upper_name)及姓名长度。
select id,Upper(name) as upper_name,length(name)
from student
where name='热dog'

聚合函数:sum、avg、count、max、min

聚合函数是一类用于对数据集进行 汇总计算 的特殊函数。它们可以对一组数据执行诸如计数、求和、平均值、最大值和最小值等操作。通常在 SELECT 语句中配合 GROUP BY 子句使用,用于对分组后的数据进行汇总分析。

常见的聚合函数包括:
count:计算指定列的行数或非空值的数量。
sum:计算指定列的数值之和。
avg:计算指定列的数值平均值。
max:找出指定列的最大值。
min:找出指定列的最小值。

# 汇总学生表中所有学生的总成绩(total_score)、平均成绩(avg_score)、最高成绩(max_score)和最低成绩(min_score)。
select 
sum(score) as total_score,avg(score) as avg_score,
max(score) as max_score,min(score) as min_score
from student

分组聚合

单字段分组:group by

分组聚合允许我们按照指定的列或字段对数据进行分组,然后对每个分组应用聚合函数。
通常使用 GROUP BY 关键字对数据进行分组

# 统计学生表中的班级编号(class_id)和每个班级的平均成绩(avg_score)
select class_id,avg(score) as avg_score
from student
group by class_id

多字段分组

多字段分组和单字段分组的实现方式几乎一致,使用 GROUP BY 语法即可

# 统计学生表中的班级编号(class_id),考试次数(exam_num)和每个班级每次考试的总学生人数(total_num)
select class_id,exam_num,count(*) as total_num
from student
group by class_id,exam_num

having子句

having子句用于在分组聚合后对分组进行过滤,即对分组后的结果进行条件筛选

having与where的区别:where用于在分组前进行筛选,having用于在分组后进行筛选

# 统计学生表中班级的总成绩超过 150 分的班级编号(class_id)和总成绩(total_score)。
select class_id,sum(score) as total_score from student
group by class_id
having sum(score)>150

查询进阶

(我们这时候需要多张表了)
学生表 student ,字段:id(学号)、name(姓名)、age(年龄)、class_id(班级编号)

班级表 class ,字段:id(班级编号)、name(班级名称)、level(班级级别)

关联查询

之前的查询操作都是在单个数据表中进行的。但有时,我们可能希望在单张表的基础上,获取更多额外数据,比如获取学生表中学生所属的班级信息等。这时,就需要使用关联查询。

cross join

CROSS JOIN 是一种简单的关联查询,不需要任何条件来匹配行,它直接将左表的 每一行 与右表的 每一行 进行组合,返回的结果是两个表的笛卡尔积

在多表关联查询的 SQL 中,我们最好在选择字段时指定字段所属表的名称(比如 e.emp_name),还可以通过给表起别名(比如 employees e)来简化 SQL 语句

# 将学生表和班级表的所有行组合在一起,并返回学生姓名(student_name)、学生年龄(student_age)、班级编号(class_id)以及班级名称(class_name)
select 
s.name as student_name,
s.age as student_age,
s.class_id as class_id,
c.name as class_name
from student as s cross join class as c

student as s cross join class as c
可以等比替换为:student as s ,class as c

inner join … on

INNER JOIN 只返回两个表中满足关联条件的交集部分,即在两个表中都存在的匹配行

# 根据学生表和班级表之间的班级编号进行匹配,返回学生姓名(student_name)、学生年龄(student_age)、班级编号(class_id)、班级名称(class_name)、班级级别(class_level)
select 
s.name as student_name,s.age as student_age,s.class_id as class_id,
c.name as class_name,c.level as class_level
from student as s inner join class as c on s.class_id = c.id
outer join … on:left join 和 right join

OUTER JOIN 根据指定的关联条件,将两个表中满足条件的行组合在一起,并 包含没有匹配的行 。
left join:以左表为基础查询,左表可以有未匹配的行
right join:以右表为基础查询,右表可以有未匹配的行

# 根据学生表和班级表之间的班级编号进行匹配,返回学生姓名(student_name)、学生年龄(student_age)、班级编号(class_id)、班级名称(class_name)、班级级别(class_level),要求必须返回所有学生的信息(即使对应的班级编号不存在)
select 
s.name as student_name,s.age as student_age,s.class_id as class_id,
c.name as class_name,c.level as class_level
from student s left join class c on s.class_id = c.id

子查询

子查询是指在一个查询语句内部嵌套另一个完整的查询语句,内层查询被称为子查询。
子查询可以用于获取更复杂的查询结果或者用于过滤数据。
当执行包含子查询的查询语句时,数据库引擎会首先执行子查询,然后将其结果作为条件或数据源来执行外层查询。

嵌套查询
# 使用子查询的方式来获取存在对应班级的学生的所有数据,返回学生姓名(name)、分数(score)、班级编号(class_id)字段。
select name,score,class_id
from student
where class_id in 
(select idfrom class
)
exists

“exists” 子查询,用于检查主查询的结果集是否存在满足条件的记录,它返回布尔值(True 或 False),而不返回实际的数据

# 使用 exists 子查询的方式来获取 不存在对应班级的 学生的所有数据,返回学生姓名(name)、年龄(age)、班级编号(class_id)字段
select name, age, class_id
from student
where not exists (select 1from classwhere class.id = student.class_id
)

组合查询

组合查询是一种将多个 SELECT 查询结果合并在一起的查询操作。
包括两种常见的组合查询操作:UNION 和 UNION ALL。
UNION 操作:它用于将两个或多个查询的结果集合并, 并去除重复的行 。即如果两个查询的结果有相同的行,则只保留一行。
UNION ALL 操作:它也用于将两个或多个查询的结果集合并, 但不去除重复的行 。即如果两个查询的结果有相同的行,则全部保留。

有一个新学生表 student_new,包含的字段和学生表完全一致

# 取所有学生表和新学生表的学生姓名(name)、年龄(age)、分数(score)、班级编号(class_id)字段,要求保留重复的学生记录select name,age,score,class_id
from student
union all
select name,age,score,class_id
from student_new

开窗函数

开窗函数是一种强大的查询工具,它允许我们在查询中进行对分组数据进行计算、 同时保留原始行的详细信息 。
开窗函数可以与聚合函数(如 SUM、AVG、COUNT 等)结合使用,但与普通聚合函数不同,开窗函数不会导致结果集的行数减少。
打个比方,可以将开窗函数想象成一种 “透视镜”,它能够将我们聚焦在某个特定的分组,同时还能看到整体的全景。

sum over(partition by …)

SUM(计算字段名) OVER (PARTITION BY 分组字段名)

# 返回每个学生的详细信息(字段顺序和原始表的字段顺序一致),并计算每个班级的学生平均分(class_avg_score)
select id,name,age,score,class_id,
avg(score) over(partition by class_id) as class_avg_score
from student
sum over by order by

sum over order by,可以实现同组内数据的 累加求和 。

# 返回每个学生的详细信息(字段顺序和原始表的字段顺序一致),并且按照分数升序的方式累加计算每个班级的学生总分(class_sum_score)
select id,name,age,score,class_id,
sum(score) over(partition by class_id order by score) as class_sum_score
from student
rank() over(partition by … order by …)

Rank 开窗函数是 SQL 中一种用于对查询结果集中的行进行 排名 的开窗函数。它可以根据指定的列或表达式对结果集中的行进行排序,并为每一行分配一个排名。在排名过程中,相同的值将被赋予相同的排名,而不同的值将被赋予不同的排名。

语法规则:
rank() over (
partition by 列名1, 列名2, … – 可选,用于指定分组列
order by 列名3 [asc|desc], 列名4 [asc|desc], … – 用于指定排序列及排序方式
) as rank_column

# 返回每个学生的详细信息(字段顺序和原始表的字段顺序一致),并且按照分数降序的方式计算每个班级内的学生的分数排名(ranking)
select id,name,age,score,class_id,
rank() over(partition by class_id order by score desc) as ranking
from student
row_number()

Row_Number 开窗函数是 SQL 中的一种用于为查询结果集中的每一行 分配唯一连续排名 的开窗函数。
Row_Number 函数为每一行都分配一个唯一的整数值,不管是否存在并列(相同排序值)的情况。每一行都有一个唯一的行号,从 1 开始连续递增。
Row_Number 开窗函数的语法如下(几乎和 Rank 函数一模一样):

# 返回每个学生的详细信息(字段顺序和原始表的字段顺序一致),并且按照分数降序的方式给每个班级内的学生分配一个编号(row_number)
select id,name,age,score,class_id,
row_number() over(partition by class_id order by score desc) as row_number
from student
lag & lead
  • lag

    Lag 函数用于获取 当前行之前 的某一列的值。它可以帮助我们查看上一行的数据。

    语法:
    lag(column_name, offset, default_value) OVER (PARTITION BY partition_column ORDER BY sort_column)

    • column_name:要获取值的列名。
    • offset:表示要向上偏移的行数。例如,offset为1表示获取上一行的值,offset为2表示获取上两行的值,以此类推。
    • default_value:可选参数,用于指定当没有前一行时的默认值。
    • PARTITION BY和ORDER BY子句可选,用于分组和排序数据。
  • lead

    Lead 函数用于获取 当前行之后 的某一列的值。它可以帮助我们查看下一行的数据。

    语法:
    lead(column_name, offset, default_value) OVER (PARTITION BY partition_column ORDER BY sort_column)

    • column_name:要获取值的列名。
    • offset:表示要向上偏移的行数。例如,offset为1表示获取上一行的值,offset为2表示获取上两行的值,以此类推。
    • default_value:可选参数,用于指定当没有前一行时的默认值。
    • PARTITION BY和ORDER BY子句可选,用于分组和排序数据。
# 返回每个学生的详细信息(字段顺序和原始表的字段顺序一致),并且按照分数降序的方式获取每个班级内的学生的前一名学生姓名(prev_name)、后一名学生姓名(next_name)
select id,name,age,score,class_id,
lag(name,1,null) over(partition by class_id order by score desc) as prev_name,
lead(name,1,null) over(partition by class_id order by score desc) as next_name 
from student

添加

  • 语法
insert into table_name(1,2,...)
values(value1,value2,...)

修改

  • 语法
    UPDATE table_name
    SET column1 = value1, column2 = value2, ...
    WHERE condition;
    
    做个小练习吧 627. 变更性别

删除

  • 语法(如果省略where子句,则会删除表中的所有记录)
    delete from 表名 where 条件;
    

本文查询参考自 http://sql.easycode.top/#/learn

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

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

相关文章

LocalSend:开源跨平台文件传输工具,让设备互通无阻

在现代社会中&#xff0c;文件共享和设备之间的互联互通已经成为日常生活中不可或缺的一部分。无论是在工作中分享文档&#xff0c;还是在朋友间传输照片和视频&#xff0c;快速而便捷的文件传输工具都显得尤为重要。通常情况下&#xff0c;我们依赖互联网或蓝牙进行文件传输&a…

解决 Vue3、Vite 和 TypeScript 开发环境下跨域的问题,实现前后端数据传递

引言 本文介绍如何在开发环境下解决 Vite 前端&#xff08;端口 3000&#xff09;和后端&#xff08;端口 80&#xff09;之间的跨域问题&#xff1a; 在开发环境中&#xff0c;前端使用的 Vite 端口与后端端口不一致&#xff0c;会产生跨域错误提示&#xff1a; Access to X…

C/C++/PYTHON 改变 console terminal cmd 字体输出颜色

C代码 #include <stdio.h>// 定义一些常用颜色的转义序列 #define RED "\x1b[31m" #define GREEN "\x1b[32m" #define YELLOW "\x1b[33m" #define BLUE "\x1b[34m" #define RESET "\x1b[0m"int main() {// 在控制台输…

android studio 更改gradle版本方法(备忘)

如果出现类似以下&#xff1a; Your build is currently configured to use Java 17.0.11 and Gradle 6.1.1. 或者类似&#xff1a; Failed to calculate the value of task ‘:app:compileDebugJavaWithJavac‘ property ‘options.generatedSo 消息时需要修改gradle版本&…

游戏引擎学习第一天

视频参考: https://www.bilibili.com/video/BV1zGDCYHErA/ 创建一个保存项目的路径 VS的安装略过&#xff0c;个人自行百度 1. vs 创建第一个CMAKE的窗口项目 game.cpp 修改如下的代码 到https://learn.microsoft.com/en-us/windows/win32/api/winbase/nf-winbase-winmain 去…

基于Spring Boot的养老保险管理系统的设计与实现,LW+源码+讲解

摘 要 如今社会上各行各业&#xff0c;都喜欢用自己行业的专属软件工作&#xff0c;互联网发展到这个时候&#xff0c;人们已经发现离不开了互联网。新技术的产生&#xff0c;往往能解决一些老技术的弊端问题。因为传统养老保险管理系统信息管理难度大&#xff0c;容错率低&a…

【Linux-进程间通信】了解信号量 + 共享内存 + 消息队列的应用

信号量&#xff08;了解&#xff09; 1.概念理论渗透 1.多个执行流&#xff08;进程&#xff09;&#xff0c;能看到的同一份资源&#xff1a;共享资源 2.被保护起来的资源-----临界资源---同步和互斥----用互斥的方式保护共享资源----临界资源 3.互斥&#xff1a;任何时刻…

Normal-GS: 3D Gaussian Splatting with Normal-Involved Rendering 论文解读

看这篇论文之前可以看一下Ref-NeRF&#xff1a;https://arxiv.org/pdf/2112.03907 目录 ​编辑 一、概述 二、相关工作 1、辐射场 2、3DGS在几何和外观上的应用 三、Normal-GS 1、3DGS 2、引入法线的策略 3、训练过程 4、损失函数 四、实验 1、渲染质量的量化对比实…

【Linux探索学习】第十弹——Linux工具篇(五):详解Linux 中 Git 工具的使用与相关知识点

Linux学习笔记&#xff1a;https://blog.csdn.net/2301_80220607/category_12805278.html?spm1001.2014.3001.5482 前言&#xff1a; Git 是一个分布式版本控制系统&#xff0c;广泛应用于软件开发中。它能够有效地管理项目的源代码&#xff0c;支持多种工作流&#xff0c;帮…

【系统文档】系统安全保障措施,安全运营保障,系统应急预案,系统验收相关资料(word原件)

一、身份鉴别 二、访问控制 三、通信完整性、保密性 四、抗抵赖 五、数据完整性 六、数据保密性 七、应用安全支撑系统设计 软件资料获取及全资料学习获取&#xff1a;本文末个人名片或进主页。

Windows Server修改 SID 操作说明

操作场景 Windows操作系统对计算机和用户的识别是通过安全标识符&#xff08;SID&#xff09;进行区分。由于基于同一镜像生产的云服务器实例 SID 相同&#xff0c;会引起无法入域的问题。如果您需要搭建 Windows 域环境&#xff0c;则需要通过修改 SID 以达到入域的目的。 本…

Java项目实战II基于Spring Boot的疗养院管理系统设计与实现(开发文档+数据库+源码)

目录 一、前言 二、技术介绍 三、系统实现 四、文档参考 五、核心代码 六、源码获取 全栈码农以及毕业设计实战开发&#xff0c;CSDN平台Java领域新星创作者&#xff0c;专注于大学生项目实战开发、讲解和毕业答疑辅导。获取源码联系方式请查看文末 一、前言 随着人口老…

Canny边缘检测中Hysteresis Thresholding(滞后阈值)名字的由来

Hysteresis Thresholding直译是滞后阈值。注意区分hysteresis、heuristic、hypothesis。 Hysteresis&#xff1a;在物理学中指滞后现象。 Canny边缘检测中滞后阈值这个名字来源于物理学中的滞后现象。通过设置两个不同的阈值来决定哪些像素属于边缘。这两个阈值分别是高阈值&…

[ Linux 命令基础 6 ] Linux 命令详解-权限和用户管理命令

&#x1f36c; 博主介绍 &#x1f468;‍&#x1f393; 博主介绍&#xff1a;大家好&#xff0c;我是 _PowerShell &#xff0c;很高兴认识大家~ ✨主攻领域&#xff1a;【渗透领域】【数据通信】 【通讯安全】 【web安全】【面试分析】 &#x1f389;点赞➕评论➕收藏 养成习…

# ubuntu创建新用户和它的家目录

ubuntu创建新用户和它的家目录 一、使用 useradd命令创建新用户和它的家目录&#xff1a; 1、命令如下&#xff1a; #sudo useradd -r -m -s /bin/bash userName #如&#xff1a;sudo useradd -r -m -s /bin/bash zhangsan2、命令参数解释 -r : 建立系统账号。 -m : 自动建…

网线类别线芯含义和传输距离以及水晶头制作标准

网线八芯每根的含义&#xff1a; 网线的八根线芯&#xff0c;也被称为RJ45网线中的8芯&#xff0c;网线采用8根线芯&#xff0c;这八根线芯各自承担着特定的功能。这8根线芯被分为4对&#xff0c;每对以特定的方式绞合在一起&#xff0c;8芯网线主要是为了减少电磁信号的相互干…

HTB:Sightless[WriteUP]

目录 连接至HTB服务器并启动靶机 使用nmap对靶机TCP端口进行开放扫描 继续使用nmap对靶机开放的TCP端口进行脚本、服务扫描 首先尝试对靶机FTP服务进行匿名登录 使用curl访问靶机80端口 使用浏览器可以直接访问该域名 使用浏览器直接访问该子域 Getshell 横向移动 查…

Golang | Leetcode Golang题解之第554题砖墙

题目&#xff1a; 题解&#xff1a; func leastBricks(wall [][]int) int {cnt : map[int]int{}for _, widths : range wall {sum : 0for _, width : range widths[:len(widths)-1] {sum widthcnt[sum]}}maxCnt : 0for _, c : range cnt {if c > maxCnt {maxCnt c}}retur…

斯坦福泡茶机器人DexCap源码解析:涵盖收集数据、处理数据、模型训练三大阶段

前言 因为我司「七月在线」关于dexcap的复现/优化接近尾声了&#xff0c;故准备把dexcap的源码也分析下。​下周则分析下iDP3的源码——为队伍「iDP3人形的复现/优化」助力 最开始&#xff0c;dexcap的源码分析属于此文《DexCap——斯坦福李飞飞团队泡茶机器人&#xff1a;带…

高中数学:概率-随机实验、样本空间、随机事件

文章目录 一、随机实验二、样本空间三、随机事件例题 四、事件运算 一、随机实验 二、样本空间 三、随机事件 例如 样本空间 Ω { a , b , c , d , e , f } 则&#xff0c;事件 A { a , b , c } &#xff0c;是一个随机事件 事件 B { d } 是一个基本事件 样本空间Ω\{a,b,c…