当前位置: 首页 > news >正文

Mysql——约束与多表查询

一、约束

1.1定义

        约束是对表中的数据进行限制的一套规则,用于防止用户向数据库中输入无效数据。它可以保证表中的数据满足特定业务规则和逻辑,从而维护数据的准确性和可靠性。

1.2作用

  • 数据完整性 :约束可以确保数据在插入、更新或删除时符合预定义的规则,从而避免数据不一致和错误。

  • 数据质量 :通过约束,可以强制执行数据的格式、范围和相关性等要求,从而提高数据的质量。

  • 优化查询 :约束可以提供有关数据结构和关系的信息,有助于优化数据库查询的性能,使数据库管理系统能够更有效地执行查询操作。

1.3常见的约束及其作用

约束描述关键字
非空约束限制该字段的数据不能为nullNOT NULL
唯一约束保证该字段数据都是唯一的、不重复的UNIQUE
主键约束主键是一行数据的唯一标识,要求非空且唯一PRIMARY KEY
默认约束保存数据时,如果未指定该字段的值,则采用默认值DEFAULT
检查约束保证字段值满足一个条件CHECK
外键约束用来让两张表的数据之间建立连接,保证数据的一致性和完整性FOREIGN KEY

非空约束 

CREATE TABLE products (product_id INT PRIMARY KEY,product_name VARCHAR(50) NOT NULL, -- 非空约束price DECIMAL(10, 2) NOT NULL, -- 非空约束description TEXT
);

 唯一约束

CREATE TABLE users (user_id INT PRIMARY KEY,username VARCHAR(50) NOT NULL UNIQUE, -- 唯一约束email VARCHAR(100) UNIQUE -- 唯一约束
);

 主键约束

CREATE TABLE employees (employee_id INT PRIMARY KEY, -- 主键约束name VARCHAR(50) NOT NULL,position VARCHAR(50),salary DECIMAL(10, 2)
);

 默认约束

CREATE TABLE blog_posts (post_id INT PRIMARY KEY,title VARCHAR(100) NOT NULL,content TEXT,created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP -- 默认值约束
);

        如果没有指定created_at,将自动使用当前时间戳。

 检查约束

CREATE TABLE orders (order_id INT PRIMARY KEY,customer_id INT NOT NULL,order_date DATE NOT NULL,status VARCHAR(20) CHECK (status IN ('Processing', 'Shipped', 'Delivered')) -- 检查约束
);

 外键约束

CREATE TABLE departments (department_id INT PRIMARY KEY, -- 主键department_name VARCHAR(50) NOT NULL
);CREATE TABLE employees (employee_id INT PRIMARY KEY,name VARCHAR(50) NOT NULL,department_id INT,FOREIGN KEY (department_id) REFERENCES departments(department_id) -- 外键约束
);

添加外键

create table 表明{字段名 数据类型,...[constraint] [外键名称] foreign key [外键字段名] references 主表(主表列名)};
alter table 表名 add constraint 外键名称 foreign key [外键字段名] references 主表(主表列名);

删除外键

alter table 表名 drop foreign key 外键名称;

外键行为

行为说明
NO ACTION当在父表中删除或者更新对应记录时,若有外键则不允许删除或更新
RESTRICT当在父表中删除或者更新对应记录时,若有外键则不允许删除或更新
CASCADE当在父表中删除或者更新对应记录时,若有外键则删除或更新外键在子表中的记录
SET NULL当在父表中删除对应记录时,若有外键则设置子表中该外键值为null(要求可以取null)
SET DEFAULT父表变更时,子表将外键列设置为一个默认的值

二、多表查询 

2.1什么是多表查询

        多表查询是指在同一个SQL语句中,从两个或多个表中检索数据。在数据库设计中,数据通常被存储在不同的表中,以避免数据冗余并提高数据完整性。通过多表查询,可以将这些表中的相关数据组合起来,以获取有意义的结果。

2.2单表查询与多表查询的区别

  • 单表查询:只涉及一个表的数据,通过WHERE子句过滤条件来查找数据。

  • 多表查询:涉及两个或多个表的数据,需要使用联接(JOIN)操作来指定表之间的关系,并通过WHERE子句过滤条件来查找数据。

2.3连接类型

1. 内联接(INNER JOIN)

内联接是默认的联接类型,它返回两个表中满足连接条件的记录。

  • 隐式内联接:
select 字段列表 from 表1,表2 where 条件...;
  • 显示内联接 :
select 字段列表 from 表1 [inner] join 表2 on 连接条件...;

2. 外联接(OUTER JOIN)

外联接可以分为以下三种类型:

  • 左外联接(LEFT OUTER JOIN):返回左表中的所有记录,以及右表中满足条件的记录。如果右表中没有匹配的记录,则返回NULL。

    select 字段列表 from 表1 left [outer] join 表二 on 条件...;
  • 右外联接(RIGHT OUTER JOIN):返回右表中的所有记录,以及左表中满足条件的记录。如果左表中没有匹配的记录,则返回NULL。

    select 字段列表 from 表1 right [outer] join 表二 on 条件...;
  • 全外联接(FULL OUTER JOIN):返回两个表中的所有记录,如果另一个表中没有匹配的记录,则返回NULL。

3. 交叉联接(CROSS JOIN)

交叉联接返回两个表的笛卡尔积,即所有可能的组合。

4. 自联接(SELF JOIN)

自联接是指将一个表与其自身进行联接。通常用于层次结构数据,例如员工表中的上下级关系,必须使用别名。

select 字段列表 from 表A 别名A join 表A 别名B on 条件...;

5.联接运算符

在SQL中,可以使用以下运算符来指定联接类型:

  • =:用于等值联接。

  • <><=>=<>等用于不等值联接。

2.4实例

        这里假设有三张表,一张订单表Orders,一张产品表Products,一张客户表Customers。

等值内联接

查询所有订单及其对应的产品信息:

SELECT Orders.OrderID, Orders.CustomerName, Products.ProductName
FROM Orders
INNER JOIN Products ON Orders.ProductID = Products.ProductID;

左外联接 

查询所有客户及其订单信息,即使某些客户没有下过订单:

SELECT Customers.CustomerName, Orders.OrderID
FROM Customers
LEFT JOIN Orders ON Customers.CustomerID = Orders.CustomerID;

全外联接

查询所有客户和所有订单,无论是客户是否有订单,还是订单是否有客户: 

SELECT Customers.CustomerName, Orders.OrderID
FROM Customers
FULL OUTER JOIN Orders ON Customers.CustomerID = Orders.CustomerID;

 三、子查询

3.1什么是子查询

        子查询是指嵌套在另一个SQL语句中的查询。它通常出现在SELECT、FROM、WHERE等子句中,主要用于为外部查询提供数据或条件。

3.2子查询的功能

  • 条件过滤:在外查询的WHERE子句中使用子查询,根据子查询返回的结果来过滤外部查询的数据。

  • 数据集:在FROM子句中使用子查询,将子查询的结果作为一个临时表来使用。

  • 赋值:在SET和WHERE子句中使用子查询,将子查询的结果赋给变量或用于更新条件。

3.3子查询语法

SELECT column1, column2, ...
FROM table_name
WHERE column_name operator (SELECT column_name FROM table_name WHERE condition);

3.4子查询类型 

  • 单行子查询:子查询返回单个值。

  • 多行子查询:子查询返回多个值,通常与IN、ANY、ALL等一起使用。

3.5示例 

条件过滤

找到价格高于产品A的所有产品:

SELECT ProductName, Price 
FROM Products 
WHERE Price > (SELECT Price FROM Products WHERE ProductName = '产品A');

临时表 

展示某个月份的销售数据:

SELECT s1.ProductID, s1.TotalSales 
FROM (SELECT ProductID, SUM(SalesAmount) AS TotalSales FROM Sales WHERE MONTH(SaleDate) = 10 GROUP BY ProductID
) s1 
WHERE s1.TotalSales > 1000;

赋值

根据子查询结果更新员工的津贴:

UPDATE Employees 
SET Bonus = (SELECT AVG(PerformanceScore) FROM Department WHERE DepartmentID = Employees.DepartmentID
) 
WHERE EmployeeID = 1001;

 

 

 

相关文章:

Mysql——约束与多表查询

一、约束 1.1定义 约束是对表中的数据进行限制的一套规则&#xff0c;用于防止用户向数据库中输入无效数据。它可以保证表中的数据满足特定业务规则和逻辑&#xff0c;从而维护数据的准确性和可靠性。 1.2作用 数据完整性 &#xff1a;约束可以确保数据在插入、更新或删除时符…...

DockerでOracle Database 23ai FreeをセットアップしMAX_STRING_SIZEを拡張する手順

DockerでOracle Database 23c FreeをセットアップしMAX_STRING_SIZEを拡張する手順 はじめに環境準備ディレクトリ作成Dockerコンテナ起動 データベース設定変更コンテナ内でSQL*Plus起動PDB操作と文字列サイズ拡張設定検証 管理者ユーザー作成注意事項まとめ はじめに Oracle…...

Unity 运用正则表达式保留字符串中的中文英文字母和数字

正则表达 正则表达式 – 语法 | 菜鸟教程 Regex 类 (System.Text.RegularExpressions) | Microsoft Learn 保留字符串中的中英数 中英数的正则表达。 patten "[\u4e00-\u9fa5A-Za-z0-9]"; 使用Regex 类匹配正则并保留。 matches Regex.Matches(str, patten)…...

vue el-table-column 单元表格的 省略号 实现

要对 el-table-column 的某一列中的每个单元格值进行处理&#xff0c;使其在文本内容超出指定宽度时显示省略号&#xff08;…&#xff09;&#xff0c;可以通过以下方法实现&#xff1a; 使用 scoped slots&#xff1a;利用 Element UI 提供的 scoped slots 自定义单元格内容…...

企业微信里可以使用的企业内刊制作工具,FLBOOK

如何让员工及时了解公司动态、行业资讯、学习专业知识&#xff0c;并有效沉淀企业文化&#xff1f;一份高质量的企业内刊是不可或缺的。现在让我来教你该怎么制作企业内刊吧 1.登录与上传 访问FLBOOK官网&#xff0c;注册账号后上传排版好的文档 2.选择模板 FLBOOK提供了丰富的…...

【数据挖掘】Pandas

Pandas 是 Python 进行 数据挖掘 和 数据分析 的核心库之一&#xff0c;提供了强大的 数据清洗、预处理、转换、分析 和 可视化 功能。它通常与 NumPy、Matplotlib、Seaborn、Scikit-Learn 等库结合使用&#xff0c;帮助构建高效的数据挖掘流程。 &#x1f4cc; 1. 读取数据 P…...

explore与explode词源故事

英语单词explore来自古法语&#xff0c;源自拉丁语&#xff0c;由前缀ex-&#xff08;出来&#xff09;加词根plor-&#xff08;叫喊&#xff09;以及末尾的小尾巴-e组成&#xff0c;字面意思就是“喊出来&#xff0c;通过叫喊声赶出来”。它为什么能表示“探索”呢&#xff1f…...

CAM350_安装

版本&#xff1a;V14.5 一、安装 打开.exe文件 选择不重启&#xff0c;然后再打开这个.exe 再来一次类似的操作 二、配置 复制patch文件夹中的这三个 &#xff0c;粘贴到掉安装目录中 设置ACT_INC_LICENSE_FILE用户环境变量来设置license管理 打开电脑的环境变量 破解完毕&am…...

51c自动驾驶~合集22

我自己的原文哦~ https://blog.51cto.com/whaosoft/11870502 #自动驾驶数据闭环最前沿论文 近几年&#xff0c;自动驾驶技术的发展日新月异。从ECCV 2020的NeRF问世再到SIGGRAPH 2023的3DGS&#xff0c;三维重建走上了快速发展的道路&#xff01;再到自动驾驶端到端技术的…...

games101 作业5

题目 光线追踪的核心算法: 1.光线的生成 2.光线与三角的相交 题解 1.光线的生成 如课件中的图所示&#xff1a; image plane 就是 代码中的scene的FrameBuffer。 但是&#xff0c;FrameBuffer 是窗口坐标系中&#xff0c;而光线是世界坐标系中的。所以我们需要将scene中的屏…...

【高并发秒杀系统设计:从Guava到Redis的6级缓存架构演进】

一、瞬时十万QPS场景分析 1.1 典型秒杀场景特征 public class SpikeScenario {// 特征1&#xff1a;瞬时流量突增private static final int QPS 100000; // 正常流量100倍// 特征2&#xff1a;资源竞争激烈private int stock 1000; // 100万人抢1000件商品// 特征3&#…...

2-程序语言基础知识

本节内容不是很多,在考试中一般是2-3分,多看教材,考试中大概都是原话 本节主要考点 1、编译程序和解释程序 2、程序语言的数据成分和控制成分(多看教材) 3、编译程序的过程(多看教材) 4、中缀、前缀与后缀表达式(增加) 教材P42-52,54-58多看一下 1、程序语言概述 机器…...

【AIGC系列】4:Stable Diffusion应用实践和代码分析

AIGC系列博文&#xff1a; 【AIGC系列】1&#xff1a;自编码器&#xff08;AutoEncoder, AE&#xff09; 【AIGC系列】2&#xff1a;DALLE 2模型介绍&#xff08;内含扩散模型介绍&#xff09; 【AIGC系列】3&#xff1a;Stable Diffusion模型原理介绍 【AIGC系列】4&#xff1…...

小米火龙CPU和其他几代温度太高的CPU是由谁代工的

小米火龙CPU”并非小米自研芯片&#xff0c;而是指搭载在小米手机上的部分高通骁龙处理器因发热问题被调侃为“火龙”。以下是几款被称为“火龙”的高通CPU及其代工情况&#xff1a; 骁龙810 骁龙810是高通历史上最著名的“火龙”之一&#xff0c;采用台积电20nm工艺代工。由于…...

在 ASP.NET Core 中压缩并减少图像的文件大小

示例代码&#xff1a;https://download.csdn.net/download/hefeng_aspnet/90294127 在当今的数字时代&#xff0c;图像是 Web 应用程序和用户体验不可或缺的一部分。但是&#xff0c;处理大型图像文件可能会导致网页加载缓慢和更高的存储费用。为了解决这个问题&#xff0c;在…...

网络流算法: Dinic算法

图论相关帖子 基本概念图的表示: 邻接矩阵和邻接表图的遍历: 深度优先与广度优先拓扑排序图的最短路径:Dijkstra算法和Bellman-Ford算法最小生成树二分图多源最短路径强连通分量欧拉回路和汉密尔顿回路网络流算法: Edmonds-Karp算法网络流算法: Dinic算法 环境要求 本文所用…...

【Godot4.3】自定义简易菜单栏节点ETDMenuBar

概述 Godot中的菜单创建是一个复杂的灾难性工作&#xff0c;往往无从下手&#xff0c;我也是不止一次尝试简化菜单的创建。 从自己去年的发明“简易树形数据”用于简化Tree控件获得灵感&#xff0c;于是尝试编写了用于表示菜单数据的EasyMenuData类&#xff0c;以及对应的纯文…...

如何杀死僵尸进程?没有那个进程?

在题主跑代码的时候遇到了这样一种很奇怪的问题&#xff1a; 可以看到显卡0没有跑任何程序但是还是被占据着大量显存&#xff0c;这种进程称为“僵尸进程”&#xff0c;并且当我想kill它的时候&#xff0c;出现下面这种情况&#xff1a; 查过各种资料&#xff0c;最后我的解决…...

Solana 核心概念全解析:账户、交易、合约与租约,高流量区块链技术揭秘!

目录 1.Solana 核心概念简述 1.1. 账户&#xff08;Account&#xff09; 1.2. 交易&#xff08;Transaction&#xff09; 1.3. 交易指令&#xff08;Instruction&#xff09; 1.4. SPL 代币 1.5. 合约&#xff08;Program&#xff09; 1.6. 租约&#xff08;Rent&#x…...

Leetcode-853. Car Fleet [C++][Java]

目录 一、题目描述 二、解题思路 Leetcode-853. Car Fleethttps://leetcode.com/problems/car-fleet/description/ 一、题目描述 There are n cars at given miles away from the starting mile 0, traveling to reach the mile target. You are given two integer array …...

用OpenMV和麦克纳姆轮给智能车做个‘漂移外挂’:从循迹到横滑的代码改造实录

OpenMV与麦克纳姆轮智能车的可控漂移改造实战 当一台普通的循迹小车突然在弯道甩出漂亮的横滑轨迹&#xff0c;围观者的惊叹声往往比技术本身更早到达终点。本文将彻底拆解如何通过运动解算逻辑重构和视觉处理优化&#xff0c;将基础麦轮智能车升级为"赛道艺术家"的…...

Apollo配置中心实战:从零到一的Docker化部署与核心配置详解

1. 为什么选择Apollo配置中心 在微服务架构中&#xff0c;配置管理一直是个让人头疼的问题。记得我第一次尝试用传统properties文件管理配置时&#xff0c;光是同步不同环境的配置就浪费了大半天时间。后来接触到Apollo&#xff0c;才发现原来配置管理可以这么优雅。 Apollo作为…...

别再让YOLO的检测框丑哭你!手把手教你根据图片大小动态调整边框粗细(附Ultralytics源码修改)

让YOLO检测框颜值翻倍&#xff1a;基于图像尺寸的动态边框优化实战 在计算机视觉领域&#xff0c;YOLO系列算法因其出色的实时性和准确性&#xff0c;已成为目标检测任务的首选工具之一。然而&#xff0c;许多开发者在实际应用中发现&#xff0c;虽然模型的检测精度令人满意&am…...

YOLO X Layout API调用指南:5行代码实现批量文档分析

YOLO X Layout API调用指南&#xff1a;5行代码实现批量文档分析 1. 为什么选择YOLO X Layout&#xff1f; 想象一下&#xff0c;你手上有1000份扫描的PDF合同需要处理&#xff0c;每份合同都包含标题、正文、签名区域和表格。传统方法可能需要人工逐页标注&#xff0c;或者使…...

Spire.Doc转PDF授权限制解析与解决方案

1. Spire.Doc转PDF的三页限制是怎么回事 第一次用Spire.Doc转换PDF时&#xff0c;我盯着生成的3页文档愣了半天——明明50页的Word文件&#xff0c;怎么输出就只剩个开头了&#xff1f;后来查文档才发现&#xff0c;这是未授权版本的硬性限制。就像试用版软件经常会有功能阉割&…...

开发环境搭建新选择:Python3.9镜像简化部署流程

开发环境搭建新选择&#xff1a;Python3.9镜像简化部署流程 你是不是也遇到过这样的场景&#xff1a;新接手一个项目&#xff0c;光是配环境就花了大半天&#xff0c;各种依赖冲突、版本不兼容&#xff0c;代码还没开始写&#xff0c;心态先崩了一半。或者&#xff0c;好不容易…...

AudioSeal保姆级教学:Gradio界面多文件批量上传与异步检测队列设置

AudioSeal保姆级教学&#xff1a;Gradio界面多文件批量上传与异步检测队列设置 1. 引言 你是不是遇到过这样的场景&#xff1f;手里有一堆音频文件&#xff0c;需要挨个检查它们是不是AI生成的&#xff0c;或者想给一批音频文件批量加上水印。手动操作不仅效率低&#xff0c;…...

C++ 智能指针的生命周期分析

C智能指针的生命周期分析 在现代C开发中&#xff0c;智能指针是管理动态内存的重要工具&#xff0c;它通过自动化的资源管理机制显著降低了内存泄漏和悬垂指针的风险。理解智能指针的生命周期对于编写高效、安全的代码至关重要。本文将深入分析智能指针的生命周期&#xff0c;…...

告别景深烦恼:用PyTorch+PyQt5打造你的专属多焦点图像融合桌面工具(附完整源码)

告别景深烦恼&#xff1a;用PyTorchPyQt5打造你的专属多焦点图像融合桌面工具 每次拍摄微距或静物时&#xff0c;是否总在景深和清晰度之间纠结&#xff1f;按下快门后才发现前景清晰时背景模糊&#xff0c;背景聚焦时前景又失焦。专业摄影师会告诉你&#xff1a;这是光学镜头的…...

K3s证书过期急救指南:5分钟搞定证书轮换(附一键脚本)

K3s证书过期急救指南&#xff1a;5分钟搞定证书轮换&#xff08;附一键脚本&#xff09; 凌晨三点&#xff0c;报警短信突然炸响——K3s集群所有服务不可用。登录控制台看到满屏的x509: certificate has expired or is not yet valid报错时&#xff0c;我才意识到证书过期这个&…...