认真学SQL——MySQL入门之DQL多表查询

news2024/12/24 22:17:04

多表查询

==本质: 把多个表通过主外键关联关系连接(join)合并成一个大表,再去查询==

知识点:

外键 foreign key

 

外键概念:

在从表(多方)创建一个字段,引用主表(一方)的主键,对应的这个字段就是外键。

外键特点:

1:从表外键的值是对主表主键的引用。
2:从表外键类型,必须与主表主键类型一致。

外键约束优点:

在插入数据时,保证了数据的准确性。
在删除数据时,保证了数据的完整性。

外键约束[了解]

修改存储引擎

-- 分类表
CREATE TABLE category
(
    cid   VARCHAR(32) PRIMARY KEY,
    cname VARCHAR(100) #分类名称
);

-- 商品表
CREATE TABLE products
(
    pid         varchar(32) PRIMARY KEY,
    pname       VARCHAR(40),
    price       DOUBLE,
    category_id varchar(32)
);

-- 演示没有外键约束出现的问题

-- 演示往从表中插入主表不存在的数据

insert into products values('p001','联想笔记本',4999,'c001'); # 插入成功,因为没有约束
insert into products values('p002','华为笔记本',4999,'c001'); # 插入成功,因为没有约束
insert into products values('p003','小米笔记本',4999,'c001'); # 插入成功,因为没有约束

-- 往主表中插入数据
insert into category values('c001','电脑');

-- 演示主表删除从表已经引用的数据
delete from category where cid = 'c001'; # 删除成功,因为没有约束

问题1:以上问题如何解决? 添加外键约束

问题2:如何添加外键约束? 前提是innodb存储引擎,myisam存储引擎不支持外键约束

注意: 如果修改了存储引擎,需要重新建表才能生效,否则还是原来的存储引擎

查看之前建表语句

show create table category; -- ENGINE=MyISAM ...
show create table products; -- ENGINE=MyISAM ...

1.交叉连接查询

(基本不会使用-得到的是两个表的乘积) [了解](不要记住)
语法:select * from A,B; # 这个结果有问题是错误的

显式格式:select * from A cross join B

隐式格式:select * from A , B

交叉连接就是表数据交叉的乘积,直接这么用会造成笛卡尔积增大太多,服务器会爆

2.交集运算:内连接查询(使用的关键字 inner join  -- inner可以省略)

显式内连接格式:select * from A inner join B on 条件;

隐式内连接格式:select * from A , B where 条件;

特点:内连接是通过匹配两个表之间的共同字段来获取结果集,只返回两个表中有匹配的数据行。内连接的结果集中只包含匹配的行。

简记:查询出多个表的交集部分

如果不加条件或者条件无效也等于使用交叉连接

-- 需求1.查询哪些分类的商品已经上架
SELECT DISTINCT c.cname FROM category c
 INNER JOIN products p ON c.cid = p.category_id
 WHERE p.flag = '1';

3.差集运算:外连接查询(使用的关键字 outer join -- outer可以省略)

-- 方式一 左外连接—left outer join

格式:select * from A left outer join B on 条件;

特点:左连接是返回左表中所有记录和右表中匹配的记录,如果右表中没有匹配的记录,则返回NULL值。左连接的结果集中包含左表中所有的行,但只包含右表中与左表匹配的行。

简记:查询出左表跟右表的交集部分和左表所有内容,没匹配到的就是null

-- 需求2.查询所有分类商品的个数

SELECT cname,COUNT(category_id) FROM category c
 LEFT OUTER JOIN products p
  ON c.cid = p.category_id
 GROUP BY cname;

-- 方式二 右外连接—right outer join

格式:select * from A right outer join B on 条件;

特点:右连接与左连接相反,返回右表中所有记录和左表中匹配的记录,如果左表中没有匹配的记录,则返回NULL值。右连接的结果集中包含右表中所有的行,但只包含左表中与右表匹配的行。

简记:查询出右表跟左表的交集部分和右表所有内容,没匹配到的就是null

子查询

解释:一条select语句结果作为另一条select语法一部分(查询条件,查询结果,表等)。

格式:select ....查询字段 ... from ... 表.. where ... 查询条件

-- 需求:查询“化妆品”分类上架商品详情

SELECT * FROM products p
 WHERE p.category_id =
 (
  SELECT c.cid FROM category c
   WHERE c.cname='化妆品'
 );

-- 需求2.查询化妆品和家电分类商品详情

select p.*
from day03.category as c
join products p on c.cid = p.category_id where c.cname in ('化妆品','化妆品');

自连接

核心思想:就是特殊的内外连接,特殊指出子啊与左表和右表是同一个表
最大特点:左右表是同一个表,那就必须要给他们起别名,才能区分
应用场景:自连接应用场景非常局限,一班都是省市县区域表或者上下级员工表

-- 需求:查询河北省下所有的城市

select city.id,city.title
from areas as city
inner join areas as prov
on city.pid=prov.id
where prov.title='河北省';

拓展:开窗函数排序

三大排序开窗函数:row_number() rank() dense_rank()
-- row_number():巧记1234 特点: 唯一且连续
-- rank(): 巧记1224 特点:并列不连续
-- dense_rank(): 巧记1223 特点: 并列且连续

开窗特点:每个开窗函数默认在表最后加一列,存储对应的开窗结果

-- 需求1.获取商品价格最低的top1商品
select *,
       row_number() over (order by price) as r1,
       rank() over (order by price) as r2,
       dense_rank() over (order by price) as r3
from day03.products;

-- 嵌套
select *
from (select *,
       row_number() over (order by price) as r1,
       rank() over (order by price) as r2,
       dense_rank() over (order by price) as r3
from day03.products) as tmp
where r2=1;

select *
from (select *,dense_rank() over (order by price desc) as r4
from products where pname like '___' or pname like '__') as t1 limit 3;

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

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

相关文章

mysql 单表 操作 最大条数验证 以及优化

1、背景 开车的多年老司机,是不是经常听到过,“mysql 单表最好不要超过 2000w”,“单表超过 2000w 就要考虑数据迁移了”,“你这个表数据都马上要到 2000w 了,难怪查询速度慢”。 2、实验 实验一把看看… 建一张表 CREATE TABL…

【论文+在线运行】AnyText:能准确写汉字的AI绘图工具

源码:https://github.com/tyxsspa/AnyText 阿里在线运行: https://modelscope.cn/studios/damo/studio_anytext/summary 论文:2311.AnyText: Multilingual Visual Text Generation And Editing 一、AnyTexT是什么? 是一个基于扩散模型的&am…

四、HTML 属性

属性是 HTML 元素提供的附加信息。 一、HTML 属性 HTML 元素可以设置属性属性可以在元素中添加附加信息属性一般描述于开始标签属性总是以名称/值对的形式出现&#xff0c;比如&#xff1a;name"value"。 二、 属性实例 HTML 链接由 <a> 标签定义。链接的地…

用户管理第2节课 -- idea 2023.2 创建表--鱼皮

二、【先确定idea版本&鱼皮是否一致&#xff0c;再决定看不看这行】建表 2.1 idea 里连接数据库&#xff0c;通过可视化建表 2.1.1 清空表中数据 的 命令 truncate 清空 2.1.2 先输入删除表&#xff0c;的命令&#xff0c;再选中这行命令&#xff0c;执行&#xff0c;…

中科驭数鄢贵海新年演讲:数字经济下的算力基础先行,DPU自主创新力量大有可为

近日&#xff0c;中科驭数创始人、CEO鄢贵海受邀在北京电视台《金融街午餐会》新年特别活动中发表新年演讲。 鄢贵海在新年演讲中提到&#xff0c;在21世纪头30年&#xff0c;我们不可思议地经历了三次重要的科技变革&#xff0c;分别是互联网的普及、移动互联网的崛起、以及人…

Linux安装rabbitMq RPM安装 以及带延迟插件

rabbitmq安装 文档中rabbitmq下载链接 以及延迟插件 网盘下载 目前下载文件中版本已经过多个服务器安装测试 完全成功 1.安装执行 rpm -ivh openssl-libs-1.0.2k-19.el7.x86_64.rpm --force --nodeps rpm -ivh libnsl-2.34-28.el9_0.x86_64.rpm --force --nodeps rpm -ivh e…

打造高效会员卡营销策划方案,提升门店业绩

在激烈的行业竞争中&#xff0c;如何有效提升店铺的业绩&#xff0c;提高客户粘性和消费频次呢&#xff1f;答案可能就在你手中——那就是有效的会员卡营销策略。下面给大家探讨如何设计会员卡营销策划方案&#xff0c;从而增加客户的忠诚度&#xff0c;并推动销售增长。以目前…

element-ui Tree 树形控件 过滤保留子级并获取过滤后的数据

本示例基于vue2 element-ui element-ui 的官网demo是只保留到过滤值一级的&#xff0c;并不会保留其子级 目标 1、Tree 树形控件 保留过滤值的子级 2、在第一次过滤数据的基础上进行第二次过滤 先看效果 Tree 树形控件 保留过滤值的子级 <el-treeclass"filter-t…

希亦、RUUFFY、鲸立内衣洗衣机怎么样?爆款对比谁是巅峰榜首

内衣洗衣机是最近这两年兴起的一款家庭小型电器&#xff0c;现在很多小伙伴都注重到卫生健康问题了&#xff0c;然而市面上有着太多三无产品的内衣洗衣机&#xff0c;不仅很难把内衣裤清洗干净还很容易出现漏电的可能&#xff0c;所以这种内衣洗衣机真的存着很危险的隐患&#…

Rockchip平台Android应用预安装功能(基于Android13)

Rockchip平台Android应用预安装功能(基于Android13) 1. 预安装应用类型 Android上的应用预安装功能&#xff0c;主要是指配置产品时&#xff0c;根据厂商要求&#xff0c;将事先准备好的第三方应用预置进Android系统。预安装分为以下几种类型&#xff1a; 安装不可卸载应用安…

阿里云服务器8080端口怎么打开?在安全组中设置

阿里云服务器8080端口开放在安全组中放行&#xff0c;Tomcat默认使用8080端口&#xff0c;8080端口也用于www代理服务&#xff0c;阿腾云atengyun.com以8080端口为例来详细说下阿里云服务器8080端口开启教程教程&#xff1a; 阿里云服务器8080端口开启教程 阿里云服务器8080端…

OpenCV-Python(24):模板匹配

原理及介绍 模板匹配是一种常用的图像处理技术&#xff0c;它用于在一幅图像中寻找与给定模板最匹配的区域(在一副大图中搜寻查找模版图像位置的方法)。模板匹配的基本思想是将模板图像在目标图像上滑动&#xff0c;并计算它们的相似度&#xff0c;找到相似度最高的位置即为匹配…

uniapp:签字版、绘画板 插件l-signature

官方网站&#xff1a;LimeUi - 多端uniapp组件库 使用步骤&#xff1a; 1、首先从插件市场将代码下载到项目 海报画板 - DCloud 插件市场 2、下载后&#xff0c;在项目中的uni_modules目录 3、最后 没有其它步骤&#xff0c;直接官网代码复制到vue文件中就可以了&#xff0c…

坐标转换 | EXCEL中批量将经纬度坐标(EPSG:4326)转换为墨卡托坐标(EPSG:3857)

1 需求 坐标系概念&#xff1a; 经纬度坐标&#xff08;EPSG:4326&#xff09;&#xff1a;WGS84坐标系&#xff08;World Geodetic System 1984&#xff09;是一种用于地球表面点的经纬度坐标系。它是美国国防部于1984年建立的&#xff0c;用于将全球地图上的点定位&#xff0…

25计算机专业考研经验贴之准备篇

Hello各位小伙伴&#xff0c;大家新年好&#xff01; 马上就要进入寒假假期了&#xff0c;25考研也该提上日程了。今天先跟大家分享一下大家在假期可以先做起来的准备工作。 【选择学校】 择校是个非常重要的内容&#xff0c;因为不同学校的考试内容是不一样的&#xff0c;有些…

CNN——LeNet

1.LeNet概述 LeNet是Yann LeCun于1988年提出的用于手写体数字识别的网络结构&#xff0c;它是最早发布的卷积神经网络之一&#xff0c;可以说LeNet是深度CNN网络的基石。 当时&#xff0c;LeNet取得了与支持向量机&#xff08;support vector machines&#xff09;性能相…

数据库进阶教学——主从复制(Ubuntu22.04主+Win10从)

目录 一、概述 二、原理 三、搭建 1、备份数据 2、主库配置Ubuntu22.04 2.1、设置阿里云服务器安全组 2.2、修改配置文件 /etc/my.cnf 2.3、重启MySQL服务 2.4、登录mysql&#xff0c;创建远程连接的账号&#xff0c;并授予主从复制权限 2.5、通过指令&#xff0c;查…

Python Web框架FastAPI——一个比Flask和Tornada更高性能的API框架

目录 一、FastAPI框架概述 二、FastAPI与Flask和Tornado的性能对比 1、路由性能 2、请求处理性能 3、内存占用 三、FastAPI的优点与特色 四、代码示例 五、注意事项 六、结论 在当今的软件开发领域&#xff0c;快速、高效地构建API成为了许多项目的关键需求。为了满足…

k8s快速搭建

VMware16Pro虚拟机安装教程VMware16.1.2安装及各版本密钥CentOS7.4的安装包:提取码&#xff1a;lp6qVMware搭建Centos7虚拟机教程 搭建完一个镜像 关机 拍摄一个快照,克隆两个作为子节点 0. 环境准备 在开始之前&#xff0c;部署Kubernetes集群机器需要满足以下几个条件&#…

实验笔记之——基于Linux服务器复现Instant-NGP及常用的tmux指令

之前博客实现了基于windows来复现Instant-NGP&#xff0c;本博文在linux服务器上测试 实验笔记之——基于windows复现Instant-NGP-CSDN博客文章浏览阅读444次&#xff0c;点赞15次&#xff0c;收藏7次。之前博客对NeRF-SLAM进行了调研&#xff0c;本博文先复现一下Intant-NGP。…