【数据库多表操作】sql语句基础及进阶
常用数据库:
数据库(Database)是按照数据结构来组织、存储和管理数据的仓库,它是长期存储在计算机内、有组织、有结构的数据集合。数据库是信息系统的核心部分,现代软件系统中大量采用了数据库管理系统(DBMS)来管理和操作数据。
- MySQL/MariaDB:由于其开源免费和社区支持,成为了最流行的关系型数据库之一。
- Oracle:商业数据库,广泛用于企业级应用。
- Microsoft SQL Server:商业数据库,主要运行在 Windows 操作系统上,广泛用于企业级应用。
- PostgreSQL:开源免费的关系型数据库,具有高级特性,例如事务、联接和触发器。
- IBM DB2:商业数据库,主要运行在 IBM 的操作系统上,如 AIX、IBM i 和 z/OS 等。
- SQLite:开源免费的嵌入式数据库,可以嵌入到其他应用程序中使用。
- MongoDB:非关系型数据库,主要用于存储非结构化数据,具有高扩展性和灵活性。
平时最常见的是MySQL数据库,是一个流行的关系型数据库管理系统,是开放源代码的。它支持各种操作系统,并提供了一组丰富的工具和库,用于处理大量的数据。MySQL 使用 SQL 语言来管理和查询数据。本文以MySQL数据库为例,讲解数据库表与表的连接操作。
简单数据库连接
在数据库中,有多种连接(Join)的方式可以使用,其中最常见的包括:内连接,左连接,右连接,外连接。
首先创建两个表t1,t2,表结构如下图所示:


sql语句如下:
use student;
create table t1(id INT PRIMARY KEY AUTO_INCREMENT,name VARCHAR(50),age INT);create table t2(id INT PRIMARY KEY AUTO_INCREMENT,name VARCHAR(50),address VARCHAR(50));insert into t1 value(1,"张三",52);
insert into t1 value(2,"王五",25);
insert into t1 value(3,"李四",36);
insert into t2 value(1,"张三","陕西");
insert into t2 value(2,"王五","北京");
insert into t2 value(3,"李四","山东");
insert into t2 value(4,"老王t1","河南");
笛卡尔积(Join)
笛卡尔积是指将两个表中的每一行都进行组合,生成一个新的表。新表的行数等于两个原表行数的乘积。
SELECT * FROM t1, t2; or
select * from t1 join t2
结果如下所示:

内连接(Inner Join)
它只返回两个表中都有匹配的行。具体来说,它只返回左边表和右边表都满足条件的记录。
select * from t1 inner join t2 on t1.id = t2.id;
结果如下:

左连接(Left Join)
它返回左边表的所有记录,以及右边表中与左边表匹配的记录。如果右边表中没有匹配的记录,则以 NULL 值填充。
select * from t2 left join t1 on t1.id = t2.id
结果如下所示

t1表中没有老王,所以t1表中老王的属性设为NULL。
右连接(Right Join)
它返回右边表的所有记录,以及左边表中与右边表匹配的记录。如果左边表中没有匹配的记录,则以 NULL 值填充。
select * from t1 right join t2 on t1.id = t2.id
和左连接基本一样,返回t2表中所有值,t1表中老王的属性设为NULL。
外连接(union)
它包含左连接和右连接,以及一些没有匹配的记录。它分为左外连接和右外连接,左外连接返回左边表的所有记录和右边表中与左边表匹配的记录,右外连接返回右边表的所有记录和左边表中与右边表匹配的记录。
SELECT *
FROM t1
LEFT JOIN t2 ON t1.id = t2.id
UNION
SELECT *
FROM t1
RIGHT JOIN t2 ON t1.id = t2.id
WHERE t1.id IS NULL;

子表查询
子查询是指在查询语句内部使用另一个完整的 SELECT 语句,子查询一般嵌套在 WHERE 子句中,作为过滤条件。子查询常常用于获取符合某些条件的数据行。
例如,假设有一个学生表 student 和一个成绩表 score,现在要查询出所有及格的学生的信息,可以使用子查询实现,如下:
SELECT *
FROM student
WHERE id IN (SELECT id FROM score WHERE score >= 60);
在这个查询中,内部的子查询 SELECT id FROM score WHERE score >= 60 返回了所有及格的学生的 id,然后外部的查询根据这些 id 查询出对应的学生信息。
concat
数据库中的concat()函数可以用来连接两个或多个字符串,在MySQL中,它的语法如下:
concat(str1,str2,...)
用t1和t2表举个例子
select concat(id,' ',name) as fullname from t1;
这个查询会将t1表里的id和name属性拼接起来连成一个字符串,并将结果显示在名为fullname的新列中,结果如下:

总结
这里总结一下sql语句中常用的关键字,如果能灵活在数据库中使用会很方便。
- SELECT:用于查询数据库中的数据。
- FROM:指定数据表。
- WHERE:用于筛选符合条件的记录。
- GROUP BY:将查询结果按照指定的列进行分组。
- HAVING:对分组后的结果进行筛选。
- ORDER BY:对查询结果进行排序。
- JOIN:用于连接两个或多个数据表。
- UNION:用于合并两个或多个SELECT语句的结果集。
- DISTINCT:用于返回不同的值,去除重复的记录。
- LIKE:用于模糊匹配查询。
- IN:用于指定一组值。
- NOT:用于否定一个条件。
- EXISTS:用于判断一个子查询是否返回数据。
- CONCAT:用于将两个或多个字符串拼接起来。
- SUM、AVG、COUNT、MAX、MIN:用于对查询结果进行聚合计算。
- AS:用于给查询结果指定别名。
相关文章:
【数据库多表操作】sql语句基础及进阶
常用数据库: 数据库(Database)是按照数据结构来组织、存储和管理数据的仓库,它是长期存储在计算机内、有组织、有结构的数据集合。数据库是信息系统的核心部分,现代软件系统中大量采用了数据库管理系统(DBM…...
DPDK和RDMA的区别
网络的发展好像在各方面都是滞后于计算和存储,时延方面也不例外,网络传输时延高,逐渐成为了数据中心高性能的瓶颈。因为传统两个节点间传输数据的网络路径上有大量的内存拷贝,导致网络传输效率低下,网络数据包的收发处…...
体验 Google Bard
环境 windows 10 64bitGoogle Bardpython 3.8 简介 本篇介绍一个开源的 Google 聊天机器人Bard 的 API 逆向工程,使用它,可以免费的使用 Bard 服务,项目地址:https://github.com/acheong08/Bard 安装及使用 通过 pip 来安装 pip &…...
MITA触摸屏维修WP4053米塔工控机控制屏维修
MITA-TEKNIK米塔触摸屏维修工控机工控屏控制器维修DISPLAY 2COM全系列型号 Mita-Teknik触摸屏维修常见故障:上电无显示,运行报故障,无法与电脑通讯,触摸无反应,触控板破裂,触摸玻璃,上电黑屏&a…...
Nacos简介 安装 配置
简介 什么是注册中心 注册中心在微服务项目中扮演着非常重要的角色,是微服务架构中的纽带,类似于通讯录,它记录了服务和服务地址的映射关系。在分布式架构中,服务会注册到这里,当服务需要调用其它服务时,…...
五、MyBatis各种查询功能
MyBatis的各种查询功能 如果查询出的数据只有一条,可以通过 实体类对象接收List集合接收Map集合接收 如果查询出的数据有多条,一定不能用实体对象接收,会抛TooManyResultsException,可以通过 实体类类型的List集合接收Map类型…...
uni-app——picker组件的用法、时间、日期、地区选择器等
1、uniapp–picker组件 <template><view class"signUp"><view class"signUp_dv1"><u-form :model"form" ref"uForm" label-width"95px"><u-form-item label"日期" :required"tr…...
什么情况需要考虑 mysql 分表
最近看到公司的其中一个数据库用户表每个月都要几百万的新用户数据增加,目前单表已经是两千多万了。所以找了 DBA 讨论,发现以前学的知识,以及网上的一些资料其实说的并不是很正确,比如 mysql 单表不建议超过一千万,我…...
系统架构师02-架构设计 20分
1.架构基本概念 *质量属性效用树:是对系统质量属性进行识别和优先级排序的重要工具 。 包括: 性能:效率指标,处理任务所需时间或单位时间内的处理量。 可用性: 可靠性: 容错:出现错误后人能保…...
【python视图3】networkx图操作示例
一、说明 根据定义,图是节点(顶点)以及已识别的节点对(称为边、链接等)的集合。在 NetworkX 中,节点可以是任何可哈希对象,例如文本字符串、图像、XML 对象、另一个图形、自定义节点对象等。 如…...
网络地址转换应用
如图所示,企业使用一台AR 路由器作为出口设备,路由器配置NAT Outbound为私网用户提供访问Internet服务,同时配置NAT Server将私网WEB服务器发布到公网上,对外网用户提供服务。运营商仅为该单位分配了一个公网IP,此地址既作为AR出接口的IP地址,也作为NAT Outbound和NAT Se…...
强化学习-Double DQN、竞争网络结构和Rainbow(第4章)
来源书籍: TENSORFLOW REINFORCEMENT LEARNING QUICK START GUIDE 《TensorFlow强化学习快速入门指南-使用Python动手搭建自学习的智能体》 著者:[美]考希克巴拉克里希南(Kaushik Balakrishnan) 译者:赵卫东 出版…...
Unity 性能优化锦集
Unity作为一款主流的游戏开发引擎,不仅提供了强大的编辑器和开发工具,还可以让开发者轻松地实现高质量的3D游戏。但是,随着游戏规模的不断扩大和玩家需求的增加,游戏的性能问题也变得越来越重要。因此,在使用Unity进行…...
JS之Map的基本使用
一、Map的基本API 创建: const map new Map()插入:map.set("name", "郑建")读取:map.get("name")判断:map.has("name")删除:map.delete大小:map.size遍历&#…...
音视频八股文(6)-- ffmpeg大体介绍和内存模型
播放器框架 常用音视频术语 • 容器/文件(Conainer/File):即特定格式的多媒体文件, 比如mp4、flv、mkv等。 • 媒体流(Stream):表示时间轴上的一段连续数据,如一 段声音…...
4.25~~~~~
接着之前PE文件结构的预习 DOS 定位到NT 怎么操作的? 用的是e_lfanew,然后是相对于文件头的偏移量(也就是raw表示方法) 现在有个问题,为什么e_lfanew 这个变量不直接存储PE头 的绝对地址呢? 比如说&…...
Android 9.0 系统设置显示主菜单添加屏幕旋转菜单实现旋转屏幕功能
1.前言 在android9.0的系统rom定制化开发中,在对系统设置进行定制开发中,有产品需求要求增加旋转屏幕功能的菜单,就是在点击旋转屏幕菜单后弹窗显示旋转0度,旋转 90度,旋转180度,旋转270度针对不同分辨率的无重力感应的大屏设备的屏幕旋转功能的实现,接下来就来分析实现…...
Python数据结构与算法-欧几里算法(p95)
一、欧几里算法原理 欧几里得公式 欧几里得算法:gcd(a,b) gcd(b, a mod b) ; mod是指模,即a/b取余数。 运算示例: gcd(60,21) gcd(21,18) gcd(18,3)gcd(3,0) 证明略 最大公约数-欧几里得求解 (…...
【故障诊断】用于轴承故障诊断的性能增强时变形态滤波方法及用于轴承断层特征提取的增强数学形态算子研究(Matlab代码实现)
💥 💥 💞 💞 欢迎来到本博客 ❤️ ❤️ 💥 💥 🏆 博主优势: 🌞 🌞 🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 …...
水羊转债,超达转债,晓鸣转债上市价格预测
水羊转债 基本信息 转债名称:水羊转债,评级:A,发行规模:6.94987亿元。 正股名称:水羊股份,今日收盘价:13.94元,转股价格:13.71元。 当前转股价值 转债面值 /…...
简易版抽奖活动的设计技术方案
1.前言 本技术方案旨在设计一套完整且可靠的抽奖活动逻辑,确保抽奖活动能够公平、公正、公开地进行,同时满足高并发访问、数据安全存储与高效处理等需求,为用户提供流畅的抽奖体验,助力业务顺利开展。本方案将涵盖抽奖活动的整体架构设计、核心流程逻辑、关键功能实现以及…...
SciencePlots——绘制论文中的图片
文章目录 安装一、风格二、1 资源 安装 # 安装最新版 pip install githttps://github.com/garrettj403/SciencePlots.git# 安装稳定版 pip install SciencePlots一、风格 简单好用的深度学习论文绘图专用工具包–Science Plot 二、 1 资源 论文绘图神器来了:一行…...
Java 8 Stream API 入门到实践详解
一、告别 for 循环! 传统痛点: Java 8 之前,集合操作离不开冗长的 for 循环和匿名类。例如,过滤列表中的偶数: List<Integer> list Arrays.asList(1, 2, 3, 4, 5); List<Integer> evens new ArrayList…...
Cesium1.95中高性能加载1500个点
一、基本方式: 图标使用.png比.svg性能要好 <template><div id"cesiumContainer"></div><div class"toolbar"><button id"resetButton">重新生成点</button><span id"countDisplay&qu…...
从零开始打造 OpenSTLinux 6.6 Yocto 系统(基于STM32CubeMX)(九)
设备树移植 和uboot设备树修改的内容同步到kernel将设备树stm32mp157d-stm32mp157daa1-mx.dts复制到内核源码目录下 源码修改及编译 修改arch/arm/boot/dts/st/Makefile,新增设备树编译 stm32mp157f-ev1-m4-examples.dtb \stm32mp157d-stm32mp157daa1-mx.dtb修改…...
BCS 2025|百度副总裁陈洋:智能体在安全领域的应用实践
6月5日,2025全球数字经济大会数字安全主论坛暨北京网络安全大会在国家会议中心隆重开幕。百度副总裁陈洋受邀出席,并作《智能体在安全领域的应用实践》主题演讲,分享了在智能体在安全领域的突破性实践。他指出,百度通过将安全能力…...
Unity | AmplifyShaderEditor插件基础(第七集:平面波动shader)
目录 一、👋🏻前言 二、😈sinx波动的基本原理 三、😈波动起来 1.sinx节点介绍 2.vertexPosition 3.集成Vector3 a.节点Append b.连起来 4.波动起来 a.波动的原理 b.时间节点 c.sinx的处理 四、🌊波动优化…...
python报错No module named ‘tensorflow.keras‘
是由于不同版本的tensorflow下的keras所在的路径不同,结合所安装的tensorflow的目录结构修改from语句即可。 原语句: from tensorflow.keras.layers import Conv1D, MaxPooling1D, LSTM, Dense 修改后: from tensorflow.python.keras.lay…...
Linux离线(zip方式)安装docker
目录 基础信息操作系统信息docker信息 安装实例安装步骤示例 遇到的问题问题1:修改默认工作路径启动失败问题2 找不到对应组 基础信息 操作系统信息 OS版本:CentOS 7 64位 内核版本:3.10.0 相关命令: uname -rcat /etc/os-rele…...
处理vxe-table 表尾数据是单独一个接口,表格tableData数据更新后,需要点击两下,表尾才是正确的
修改bug思路: 分别把 tabledata 和 表尾相关数据 console.log() 发现 更新数据先后顺序不对 settimeout延迟查询表格接口 ——测试可行 升级↑:async await 等接口返回后再开始下一个接口查询 ________________________________________________________…...
