读SQL学习指南(第3版)笔记06_连接和集合
1. 连接
1.1. 笛卡儿积
1.1.1. 交叉连接(cross join)
1.1.2. 查询并没有指定两个数据表应该如何连接,数据库服务器就生成了笛卡儿积
1.1.2.1. 两个数据表的所有排列组合
1.1.3. 很少会用到(至少不会特意用到)
1.1.3.1. 使用频率并不高
1.1.4. mysql
-> SELECT c.first_name, c.last_name, a.address-> FROM customer c JOIN address a;
1.1.5. 为2020年的每一天生成一行,但是数据库中没有包含每天一行的数据表
1.1.5.1. 涉及交叉连接、外连接、日期函数、分组、集合运算(union all)和聚合函数(count())
1.1.5.2. sql
SELECT '2020-01-01' dt
UNION ALL
SELECT '2020-01-02' dt
UNION ALL
SELECT '2020-01-03' dt
UNION ALL
...
...
...
SELECT '2020-12-29' dt
UNION ALL
SELECT '2020-12-30' dt
UNION ALL
SELECT '2020-12-31' dt
1.1.5.3. mysql
-> SELECT ones.num + tens.num + hundreds.num-> FROM-> (SELECT 0 num UNION ALL-> SELECT 1 num UNION ALL-> SELECT 2 num UNION ALL-> SELECT 3 num UNION ALL-> SELECT 4 num UNION ALL-> SELECT 5 num UNION ALL-> SELECT 6 num UNION ALL-> SELECT 7 num UNION ALL-> SELECT 8 num UNION ALL-> SELECT 9 num) ones-> CROSS JOIN-> (SELECT 0 num UNION ALL-> SELECT 10 num UNION ALL-> SELECT 20 num UNION ALL-> SELECT 30 num UNION ALL-> SELECT 40 num UNION ALL-> SELECT 50 num UNION ALL-> SELECT 60 num UNION ALL-> SELECT 70 num UNION ALL-> SELECT 80 num UNION ALL-> SELECT 90 num) tens-> CROSS JOIN-> (SELECT 0 num UNION ALL-> SELECT 100 num UNION ALL-> SELECT 200 num UNION ALL-> SELECT 300 num) hundreds;
1.1.5.4. 如果生成{0, 1, 2, 3, 4, 5, 6, 7, 8, 9}、{0, 10, 20, 30, 40, 50, 60, 70, 80, 90}和{0,100, 200, 300}这3个集合的笛卡儿积,并将这3列的值相加,就可以得到包含0~399的所有数值的400行结果集
1.1.5.5. mysql
-> SELECT DATE_ADD('2020-01-01',-> INTERVAL (ones.num + tens.num + hundreds.num) DAY) dt-> FROM-> (SELECT 0 num UNION ALL-> SELECT 1 num UNION ALL-> SELECT 2 num UNION ALL-> SELECT 3 num UNION ALL-> SELECT 4 num UNION ALL-> SELECT 5 num UNION ALL-> SELECT 6 num UNION ALL-> SELECT 7 num UNION ALL-> SELECT 8 num UNION ALL-> SELECT 9 num) ones-> CROSS JOIN-> (SELECT 0 num UNION ALL-> SELECT 10 num UNION ALL-> SELECT 20 num UNION ALL-> SELECT 30 num UNION ALL-> SELECT 40 num UNION ALL-> SELECT 50 num UNION ALL-> SELECT 60 num UNION ALL-> SELECT 70 num UNION ALL-> SELECT 80 num UNION ALL-> SELECT 90 num) tens-> CROSS JOIN-> (SELECT 0 num UNION ALL-> SELECT 100 num UNION ALL-> SELECT 200 num UNION ALL-> SELECT 300 num) hundreds-> WHERE DATE_ADD('2020-01-01',-> INTERVAL (ones.num + tens.num + hundreds.num) DAY) < '2021-01-01'-> ORDER BY 1;
1.1.5.6. 无须人为介入,结果集会自动包含额外的闰日(2月29日),这是由数据库服务器通过将2020年1月1日加上59天计算得出
1.2. 内连接
1.2.1. 增加了连接类型(注意关键字inner)
1.2.2. mysql
-> SELECT c.first_name, c.last_name, a.address-> FROM customer c JOIN address a-> ON c.address_id = a.address_id;
1.2.3. sql
SELECT c.first_name, c.last_name, a.address
FROM customer c INNER JOIN address aON c.address_id = a.address_id;
1.2.4. 如果用于连接两个数据表的列名相同,则可以使用using子句替代on
1.2.4.1. sql
SELECT c.first_name, c.last_name, a.address
FROM customer c INNER JOIN address aUSING (address_id);
1.2.4.2. using是一种只能在某些特定情况下使用的简写表示法
1.3. 外连接(outer join)
1.3.1. 如果要将一个数据表中的所有行全部纳入结果集,不管其在另一个数据表中是否存在匹配
1.3.2. mysql
-> SELECT f.film_id, f.title, count(i.inventory_id) num_copies-> FROM film f-> LEFT OUTER JOIN inventory i-> ON f.film_id = i.film_id-> GROUP BY f.film_id, f.title;
1.3.3. 关键字left和right只是告知服务器哪个数据表的数据可以不足
1.3.4. outer关键字是可选的,可以使用A left join B来代替
1.4. 自然连接(natural join)
1.4.1. 依靠多个数据表之间相同的列名来推断适合的连接条件
1.4.2. mysql
-> SELECT c.first_name, c.last_name, date(r.rental_date)-> FROM customer c-> NATURAL JOIN rental r;
Empty set (0.04 sec)
1.4.3. 数据库服务器检查数据表定义并添加了连接条件r.customer_id = c.customer_id
1.4.4. 应该避免使用这种连接类型,而使用带有显式连接条件的内连接
1.5. 连接的旧方法
1.5.1. mysql
-> SELECT c.first_name, c.last_name, a.address-> FROM customer c, address a-> WHERE c.address_id = a.address_id;
1.5.2. 不需要on子句
1.5.3. from子句中的数据表名以逗号分隔
1.5.4. 连接条件出现在where子句中
1.6. ANSI连接语法
1.6.1. 连接条件和过滤条件被分隔在两个不同的子句中(on子句和where子句),使得查询语句更易于理解
1.6.2. 两个数据表的连接条件出现在其各自单独的on子句中,这样就不太可能错误地忽略连接条件
1.6.3. 使用SQL92连接语法的查询语句可以在各种数据库服务器间移植,而旧语法在不同服务器上的表现略有不同
1.7. 连接顺序
1.7.1. 各数据表在from子句中出现的顺序并不重要
1.7.1.1. 服务器使用从数据库对象收集的统计信息,在3个数据表中选择一个作为起点(所选择的数据表被称为驱动表),然后确定其他数据表的连接顺
1.7.2. 如果认为查询语句中的数据表应该始终以特定的顺序连接,可以将数据表按照需要的顺序排列
1.7.2.1. 在MySQL中指定straight_join关键字
1.7.2.1.1. sql
SELECT STRAIGHT_JOIN c.first_name, c.last_name, ct.city
FROM city ctINNER JOIN address aON a.city_id = ct.city_idINNER JOIN customer cON c.address_id = a.address_id
1.7.2.2. 在SQL Server中请求force order选项
1.7.2.3. 在Oracle Database中使用ordered或leading优化器
1.7.3. 三路外连接
1.7.3.1. mysql
-> SELECT f.film_id, f.title, i.inventory_id, r.rental_date-> FROM film f-> LEFT OUTER JOIN inventory i-> ON f.film_id = i.film_id-> LEFT OUTER JOIN rental r-> ON i.inventory_id = r.inventory_id-> WHERE f.film_id BETWEEN 13 AND 15;
1.8. 自连接
1.8.1. mysql
-> SELECT f.title, f_prnt.title prequel-> FROM film f-> INNER JOIN film f_prnt-> ON f_prnt.film_id = f.prequel_film_id-> WHERE f.prequel_film_id IS NOT NULL;
2. 集合
2.1. 在对两个数据集执行集合运算时
2.1.1. 两个数据集的列数必须相等
2.1.2. 两个数据集各列的数据类型必须相同
2.1.2.1. 数据库服务器必须能够将一种数据类型转换成另一种数据类型
2.2. union运算符
2.2.1. mysql
-> SELECT 1 num, 'abc' str-> UNION-> SELECT 9 num, 'xyz' str;
2.2.2. union会对组合后的集合进行排序并去除重复项
2.2.3. union all则不然
2.3. intersect运算符
2.3.1. ANSI SQL规范中定义了用于执行交集运算的intersect运算符
2.3.2. ANSI SQL规范还提供了不去除重复行的intersect all运算符
2.3.2.1. 唯一实现了intersect all运算符的数据库服务器是IBM DB2 Universal Server
2.3.3. MySQL 8.0版还未实现intersect运算符
2.3.4. Oracle或SQL Server 2008中可以使用
2.4. except运算符
2.4.1. ANSI SQL规范提供了执行差集运算的except运算符
2.4.2. ANSI SQL规范还提供了except all运算符
2.4.2.1. 只有IBM的 DB2 Universal Server实现了该运算符
2.4.3. MySQL 8.0版也没有实现except运算符
2.4.4. Oracle Database需要使用非ANSI兼容的minus运算符替代except运算符
2.5. 对符合查询结果排序
2.5.1. mysql
-> SELECT a.first_name fname, a.last_name lname-> FROM actor a-> WHERE a.first_name LIKE 'J%' AND a.last_name LIKE 'D%'-> UNION ALL-> SELECT c.first_name, c.last_name-> FROM customer c-> WHERE c.first_name LIKE 'J%' AND c.last_name LIKE 'D%'-> ORDER BY lname, fname;
2.6. 集合运算的优先级
2.6.1. 包含3个或以上查询语句的复合查询,是以自顶向下的顺序来评估查询的
2.6.2. 根据ANSI SQL规范,intersect运算符拥有比其他集合运算符更高的优先级
2.6.3. 可以将查询放入括号内,以明确指定查询的执行顺序
2.6.3.1. MySQL目前还不允许在复合查询中使用括号
2.6.3.2. 将相邻查询放入括号中,以覆盖复合查询默认的自顶向下的处理方式
相关文章:

读SQL学习指南(第3版)笔记06_连接和集合
1. 连接 1.1. 笛卡儿积 1.1.1. 交叉连接(cross join) 1.1.2. 查询并没有指定两个数据表应该如何连接,数据库服务器就生成了笛卡儿积 1.1.2.1. 两个数据表的所有排列组合 1.1.3. 很少会用到(至少不会特意用到) 1.…...
C#学习,结构,面向对象,类
结构和类 结构是从过程化程序设计中保留下来的一种数据类型,类则是面向对象程序设计中最基本的、也是最重要的概念。 结构 结构是一种值类型,通常用来封装一组相关的变量,结构中可以包含构造函数、变量、字段、方法、属性、运算符、事件和…...

【PHP】文件操作
文章目录 文件编程的必要性目录操作其它目录操作递归遍历目录PHP5常见文件操作函数PHP4常见文件操作函数其他文件操作函数 文件编程的必要性 文件编程指利用PHP代码针对文件(文件夹)进行增删改查操作。 在实际开发项目中,会有很多内容&…...

科创板50ETF期权交易:详细规则、费用、保证金和开户攻略
科创板50ETF期权是指以科创板50ETF为标的资产的期权合约。科创板50ETF是由交易所推出的一种交易型开放式指数基金(ETF),旨在跟踪科创板50指数的表现,下文介绍科创板50ETF期权交易:详细规则、费用、保证金和开户攻略&am…...

怎么把图片放大并且清晰?有详细的方法步骤
怎么把图片放大并且清晰?数字图像处理中的图片放大是许多行业和领域中广泛应用的一项技术。常规的放大方法通过插值或复制像素的方式增加像素数,但这会导致失真和模糊。无损放大是一种特殊的放大方法,它可以通过数学算法来增加图片的尺寸&…...
C++ 构造函数、析构函数调用虚函数
C虚函数是通过虚表实现的,虚函数的地址记录在需表中,只对象完成构造完成后,虚函数的地址才最终确定。 构造函数中调用虚函数 基类先于派生类构造,所以构造时没法调用到派生类的虚函数,也就是说只能调用到自己&#x…...

工业状态监测如何选择合适的无线技术?
工业领域的状态监测在提高生产效率和产品质量方面起着关键作用。过去依赖于预防性维护和例行检查的方式已经不再能满足日益复杂的生产需求,随着工业物联网(IIoT)的兴起,设备状态监测逐渐成为一种关键策略,催生了预测性…...

Mysql45讲学习笔记
前言:这篇文章主要总结事务,锁、索引的一些知识点,然后分享一下自己学习小心得,我会从点到线在到面展开说说,对于学习任何知识,我们都应该藐其全貌,不要一开始就选入细节 基础 一、基础架构&a…...
Neither the JAVA_HOME nor the JRE_HOME environment variable is defined
报错描述 情景一 1Panel在"主机-->进程守护"通过命令"nohup /opt/tomcat/bin/startup.sh > /opt/supersivor/tomcat/nohup.log &"创建守护进程,运行日志如下: #--------------------------------------------------------…...

opencv 水果识别+UI界面识别系统,可训练自定义的水果数据集
目录 一、实现和完整UI视频效果展示 主界面: 测试图片结果界面: 自定义图片结果界面: 二、原理介绍: 图像预处理 HOG特征提取算法 数据准备 SVM支持向量机算法 预测和评估 完整演示视频: 完整代码链接 一、…...
TypeScript数组和对象的操作
TypeScript数组和对象的操作 一、数组的声明二、数组初始化三、数组元素赋值、添加、更改四、删除五、合并、断开数组六、查找数组元素七、连接数组元素八、排序、反序数组九、遍历数组,对象 一、数组的声明 let arr1: Array<number>; let arr2: number[];二…...

docker之Compose与DockerSwarm
目录 Compose 简介 概念 为什么需要? 配置字段 常用命令 安装 1.下载 2.授权 使用 1.创建文件 2.启动 docker Swarm 关键概念 调度策略 spread binpack random 特性 集群部署 1.准备 2.创建swarm并添加节点 在主服务器上创建swarm集群 节点…...
VS Code 使用 clang++ 编译,使用 cppvsdbg 或 lldb 调试的配置方法
需要安装的 VS Code LLVM VS Code 需要安装的插件: C/C(用来配置 c_cpp_properties.json) CodeLLDB(如果你要用 lldb 调试,那么这个插件就需要安装,用来连接到 lldb 调试器) 流程 我们都…...
android11,12 Launcher3编译什么
1首先看看手机里的是什么 adb shell pm path com.android.launcher3 package:/system_ext/priv-app/Launcher3QuickStep/Launcher3QuickStep.apk 然后就编译Launcher3QuickStep 2push apk 没什么说的,push到对应的文件夹 /system_ext/priv-app/Launcher3Quick…...

Go 第三方库引起的线上问题、如何在线线上环境进行调试定位问题以及golang开发中各种问题精华整理总结
Go 第三方库引起的线上问题、如何在线线上环境进行调试定位问题以及golang开发中各种问题精华整理总结。 01 前言 在使用 Go 语言进行 Web 开发时,我们往往会选择一些优秀的库来简化 HTTP 请求的处理。其中,go-resty 是一个被广泛使用的 HTTP 客户端。…...
【C语言】#define 宏定义初步使用
使用宏定义可以防止出错,提高可移植性,可读性,方便性等。 下面列举了一些成熟软件中常用的宏定义。 重新定义一些基本类型 重新定义一些类型,防止由于各种平台和编译器的不同,而产生的类型字节数差异,方便…...
项目里面怎么解决跨域的?
一.前端配置跨域 proxy解决跨域 在vue.config.js中通过proxy devServer中配置反向代理。 devServer: {port: port,open: true,overlay: {warnings: false,errors: true},// 配置反向代理proxy: {// 当地址中有/api的时候会触发代理机制/api: {target: http://ihrm-java.ithe…...
Oracle 批量导出表注释和主键
–查询分表(目前分了16张表) –先查询注释为空的表,也就是11表做示例,统计出来以后11批量修改成1 select owner,column_name,comments,table_name from all_col_comments a where a.table_name like ‘TB%1’ and a.comments is n…...

Linux C++ 海康摄像头获取过车信息
代码 void CALLBACK MessageCallback(LONG lCommand, NET_DVR_ALARMER *pAlarmer, char *pAlarmInfo, DWORD dwBufLen, void *pUser) {printf("enter MessageCallback---------------------->\n");int i;NET_DVR_ALARMINFO_V30 struAlarmInfo;memcpy(&struAl…...

iOS逆向:越狱及相关概念的介绍
在上一篇内容中我们介绍了App脱壳的技术,今天我们来介绍一个和iOS逆向密切相关的知识:越狱。 iOS操作系统的封闭性一直是开发者们关注的焦点之一。为了突破Apple的限制,越狱技术应运而生。本文将深入探讨iOS越狱,包括可越狱的版本…...

(十)学生端搭建
本次旨在将之前的已完成的部分功能进行拼装到学生端,同时完善学生端的构建。本次工作主要包括: 1.学生端整体界面布局 2.模拟考场与部分个人画像流程的串联 3.整体学生端逻辑 一、学生端 在主界面可以选择自己的用户角色 选择学生则进入学生登录界面…...
MySQL 隔离级别:脏读、幻读及不可重复读的原理与示例
一、MySQL 隔离级别 MySQL 提供了四种隔离级别,用于控制事务之间的并发访问以及数据的可见性,不同隔离级别对脏读、幻读、不可重复读这几种并发数据问题有着不同的处理方式,具体如下: 隔离级别脏读不可重复读幻读性能特点及锁机制读未提交(READ UNCOMMITTED)允许出现允许…...

基于uniapp+WebSocket实现聊天对话、消息监听、消息推送、聊天室等功能,多端兼容
基于 UniApp + WebSocket实现多端兼容的实时通讯系统,涵盖WebSocket连接建立、消息收发机制、多端兼容性配置、消息实时监听等功能,适配微信小程序、H5、Android、iOS等终端 目录 技术选型分析WebSocket协议优势UniApp跨平台特性WebSocket 基础实现连接管理消息收发连接…...

(转)什么是DockerCompose?它有什么作用?
一、什么是DockerCompose? DockerCompose可以基于Compose文件帮我们快速的部署分布式应用,而无需手动一个个创建和运行容器。 Compose文件是一个文本文件,通过指令定义集群中的每个容器如何运行。 DockerCompose就是把DockerFile转换成指令去运行。 …...

USB Over IP专用硬件的5个特点
USB over IP技术通过将USB协议数据封装在标准TCP/IP网络数据包中,从根本上改变了USB连接。这允许客户端通过局域网或广域网远程访问和控制物理连接到服务器的USB设备(如专用硬件设备),从而消除了直接物理连接的需要。USB over IP的…...
在鸿蒙HarmonyOS 5中使用DevEco Studio实现企业微信功能
1. 开发环境准备 安装DevEco Studio 3.1: 从华为开发者官网下载最新版DevEco Studio安装HarmonyOS 5.0 SDK 项目配置: // module.json5 {"module": {"requestPermissions": [{"name": "ohos.permis…...
「全栈技术解析」推客小程序系统开发:从架构设计到裂变增长的完整解决方案
在移动互联网营销竞争白热化的当下,推客小程序系统凭借其裂变传播、精准营销等特性,成为企业抢占市场的利器。本文将深度解析推客小程序系统开发的核心技术与实现路径,助力开发者打造具有市场竞争力的营销工具。 一、系统核心功能架构&…...
git: early EOF
macOS报错: Initialized empty Git repository in /usr/local/Homebrew/Library/Taps/homebrew/homebrew-core/.git/ remote: Enumerating objects: 2691797, done. remote: Counting objects: 100% (1760/1760), done. remote: Compressing objects: 100% (636/636…...

Unity中的transform.up
2025年6月8日,周日下午 在Unity中,transform.up是Transform组件的一个属性,表示游戏对象在世界空间中的“上”方向(Y轴正方向),且会随对象旋转动态变化。以下是关键点解析: 基本定义 transfor…...

Sklearn 机器学习 缺失值处理 获取填充失值的统计值
💖亲爱的技术爱好者们,热烈欢迎来到 Kant2048 的博客!我是 Thomas Kant,很开心能在CSDN上与你们相遇~💖 本博客的精华专栏: 【自动化测试】 【测试经验】 【人工智能】 【Python】 使用 Scikit-learn 处理缺失值并提取填充统计信息的完整指南 在机器学习项目中,数据清…...