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

MySql数据库常用指令(五)多表连接

MySql数据库常用指令(五)多表连接

  • 一、内连接,或等值连接
  • 二、左连接
  • 三、右连接

实际应用中,我们常常要连接几个不同的MySQL表,因此在 SELECT, UPDATE 和 DELETE 语句中使用 Mysql 的 JOIN 来联合多表查询

INNER JOIN(内连接,或等值连接):获取两个表中字段匹配关系的记录。 LEFT
JOIN(左连接):获取左表所有记录,即使右表没有对应匹配的记录。 RIGHT JOIN(右连接): 与 LEFT JOIN

注:文中TEST为测试所用数据库,根据实际应用修改

一、内连接,或等值连接

获取两个表中字段匹配关系的记录。
INNER JOIN

mysql> SELECT a.id, a.author, b.count FROM test1_tbl a INNER JOIN test2_tbl b ON a.author = b.author;

注:有表test1和表test2,test1表(id,author,time),test2表(author,count)
注:此语句意思为:将两表值分别用a、b区分,读取所有test1表author在test2表上对应的count字段值,并且展示(a.id,a.author,b.count)

等价于:
WHERE 子句

mysql> SELECT a.id, a.author, b.count FROM test1_tbl a, test2_tbl b WHERE a.author = b.author;

二、左连接

获取左表所有记录,即使右表没有对应匹配的记录。

mysql> SELECT a.id, a.author, b.count FROM test1_tbl a LEFT JOIN test2_tbl b ON a.author = b.author;

注:该语句会读取左边的数据表 test1_tbl 的所有选取的字段数据,即使在右侧表 test2_tbl中 没有对应的 author 字段值。

三、右连接

与 LEFT JOIN 相反,用于获取右表所有记录,即使左表没有对应匹配的记录。

mysql> SELECT a.id, a.author, b.count FROM test1_tbl a RIGHT JOIN test2_tbl b ON a.author = b.author;

相关文章:

MySql数据库常用指令(五)多表连接

MySql数据库常用指令(五)多表连接 一、内连接,或等值连接二、左连接三、右连接 实际应用中,我们常常要连接几个不同的MySQL表,因此在 SELECT, UPDATE 和 DELETE 语句中使用 Mysql 的 JOIN 来联合多表查询 INNER JOIN(内…...

Centos7使用rpm安装mysql 5.7.43

Centos7使用rpm安装mysql 5.7.43 1、下载rpm包 wget https://downloads.mysql.com/archives/get/p/23/file/mysql-5.7.43-1.el7.x86_64.rpm-bundle.tar2、解压并安装 tar xf mysql-5.7.43-1.el7.x86_64.rpm-bundle.tar yum -y install mysql-*3、按需修改mysql配置 #注意&a…...

补充:如何提高selenium的运行速度?

已经通读该专栏文章的同学,或许对UI自动化测试有了一定的掌握,细心的同学肯定会发现一个问题,当用例量达到一定程度时,对于整体用例的执行速度肯定不会很满意。除了应用多线程运行用例的方式加快速度,有没有其他的方法呢? 今天告诉大家,方法是有的!也是本人新学的。即…...

使用Python+Redis实现文章投票网站后端功能

1.实现投票功能,2.创建文章数据,3.对文章进行排序。 实现投票功能 实现投票功能,要注重文章的时效性与投票的公平性,所以需要给投票功能加上一些约束条件: 文章发布满一个星期后&…...

SpringBoot 环境使用 Redis + AOP + 自定义注解实现接口幂等性

目录 一、前言二、主流实现方案介绍2.1、前端按钮做加载状态限制(必备)2.2、客户端使用唯一标识符2.3、服务端通过检测请求参数进行幂等校验(本文使用) 三、代码实现3.1、POM3.2、application.yml3.3、Redis配置类3.4、自定义注解…...

Leetcode—18.四数之和【中等】

2023每日刷题&#xff08;四十一&#xff09; Leetcode—18.四数之和 实现代码 class Solution { public:vector<vector<int>> fourSum(vector<int>& nums, int target) {vector<vector<int>> ans;sort(nums.begin(), nums.end());int n …...

springsecurity6配置二

一、springsecurity6自定义认证异常处理器 1.1 AuthenticationEntryPointImpl.java package com.school.information.core.security.handler;import com.alibaba.fastjson.JSON; import com.school.information.enums.result.ResultStatusEnum; import com.school.informatio…...

php如何对比浮点数大小(bccomp函数)

第一部分&#xff0c;常规例子&#xff1a; 例1&#xff1a;左边比右边小&#xff0c;结果&#xff1a;-1 //示例&#xff0c;左边比右边小返回值&#xff1a;-1 $price1 2.14; $price2 3.14; $result bccomp($price1, $price2, 2); echo 对比结果&#xff1a;.$result;//…...

服务号和订阅号哪个好

服务号和订阅号有什么区别&#xff1f;服务号转为订阅号有哪些作用&#xff1f;在推送频率上来看&#xff0c;服务号每月能推送四条消息&#xff0c;而订阅号可以每天&#xff08;24小时&#xff09;推送一条消息。如果企业开通公众号的目的是提供服务&#xff0c;例如售前资讯…...

面试问题--智能指针

什么是智能指针&#xff1f; 当你在编写程序时&#xff0c;可能需要在运行时动态分配内存来存储数据。在传统的C中&#xff0c;你可能会使用 new 和 delete 操作符来手动管理内存。但是这样容易出现一些问题&#xff0c;比如忘记释放内存导致内存泄漏&#xff0c;或者释放了之…...

向量机SVM原理理解和实战

目录 概念场景导入 点到超平面的距离公式 最大间隔的优化模型 硬间隔、软间隔和非线性 SVM 用 SVM 如何解决多分类问题 1. 一对多法 2. 一对一法 SVM主要原理和特点 原理 优点 缺点 支持向量机模型分类 SVM实战如何进行乳腺癌检测 数据集 字段含义 代码实现 参…...

什么是 Node.js?

在 Node.js 出现之前&#xff0c;最常见的 JavaScript 运行时环境是浏览器&#xff0c;也叫做 JavaScript 的宿主环境。浏览器为 JavaScript 提供了 DOM API&#xff0c;能够让 JavaScript 操作浏览器环境&#xff08;JS 环境&#xff09;。 2009 年初 Node.js 出现了&#xf…...

系列九、声明式事务(xml方式)

一、概述 声明式事务(declarative transaction management)是Spring提供的对程序事务管理的一种方式&#xff0c;Spring的声明式事务顾名思义就是采用声明的方式来处理事务。这里所说的声明&#xff0c;是指在配置文件中声明&#xff0c;用在Spring配置文件中声明式的处理事务来…...

c盘清理——常用方法和工具整理

背景 最近c盘满了&#xff0c;只剩下1-2G&#xff0c;周末有空清理一下。对这块不太熟悉&#xff0c;下面只是把今天网上看到的比较好用的工具整理一下。 使用工具 磁盘大小查看工具——TreeSize&#xff08;收费&#xff09; 之前都是右键一个个看每个文件的大小&#xff0…...

【React】打包体积分析 source-map-explorer

通过分析打包体积&#xff0c;才能知道项目中的哪部分内容体积过大&#xff0c;方便知道哪些包需要进一步优化。 使用步骤 安装分析打包体积的包&#xff1a;npm i source-map-explorer在 package.json 中的 scripts 标签中&#xff0c;添加分析打包体积的命令对项目打包&…...

Zookeeper(一):在WSL单机搭建Zookeeper伪集群

目录 Zookeeper1 启动单个Zookeeper实例1.1 下载Zookeeper安装包并解压1.2 添加环境变量1.3 修改默认配置1.4 新建数据存储目录和日志目录1.5 启动Zookeeper1.6 停止Zookeeper 2 搭建Zookeeper集群2.1 新建集群目录2.2 配置环境变量2.3 创建节点目录2.4 修改配置2.5 创建节点ID…...

Go语法的特殊之处

上文我们讲了GO模块引入指令Go Mod&#xff0c;本文讲述Go语法的特殊之处 : 单变量 : hello:“hello” Go 语言中新增了一个特殊的运算符:&#xff0c;这个运算符可以使变量在不声明的情况下直接被赋值使用。其使用方法和带值声明变量类似&#xff0c;只是少了var关键字&…...

浏览器v8垃圾回收机制和内存泄漏分析-初级

借鉴&#xff1a;一文搞懂V8引擎的垃圾回收 - 掘金 (juejin.cn) 聊聊V8引擎的垃圾回收 - 掘金 (juejin.cn) 内存泄漏方向&#xff1a; 1、全局变量 未手动清除 2、定时器 未手动清除 3、闭包中使用了匿名函数 未手动清除 4、dom被赋值使用后 未手动清除 其他解决方式 1、…...

hdlbits系列verilog解答(7420 chip)-49

文章目录 一、问题描述二、verilog源码三、仿真结果一、问题描述 本次将实现7420逻辑芯片,它内部有2个4输入的与非门电路,外部有8个输入和2个输出管脚,功能框图如下所示: 二、verilog源码 module top_module ( input p1a, p1b, p1c, p1d,output p1y,input p2a, p2b, p2c…...

Sentinel核心类解读:Entry

默认情况下&#xff0c;Sentinel会将controller中的方法作为被保护资源&#xff0c;Sentinel中的资源用Entry来表示。 Sentinel中Entry可以理解为每次进入资源的一个凭证&#xff0c;如果调用SphO.entry()或者SphU.entry()能获取Entry对象&#xff0c;代表获取了凭证&#xff…...

别再只会用cat了!Linux日志文件排查实战:用tail、grep、less搞定/var/log/messages

别再只会用cat了&#xff01;Linux日志文件排查实战&#xff1a;用tail、grep、less搞定/var/log/messages 当你面对一台突然报错的Linux服务器&#xff0c;第一反应是什么&#xff1f;大多数新手会本能地输入cat /var/log/messages&#xff0c;然后被瞬间刷屏的日志淹没。这种…...

保姆级教程:ROS Melodic下用usb_cam驱动UVC摄像头,解决花屏和像素格式警告

ROS Melodic下UVC摄像头驱动配置全指南&#xff1a;从花屏排查到像素格式优化 第一次在ROS中连接USB摄像头时&#xff0c;看到屏幕上闪烁的彩色噪点和扭曲图像&#xff0c;那种挫败感我至今记忆犹新。这不是简单的设备故障&#xff0c;而是ROS视觉开发中典型的"入门仪式&q…...

免费开源的Altium电路图转换器:轻松查看SchDoc文件无需专业软件

免费开源的Altium电路图转换器&#xff1a;轻松查看SchDoc文件无需专业软件 【免费下载链接】python-altium Altium schematic format documentation, SVG converter and TK viewer 项目地址: https://gitcode.com/gh_mirrors/py/python-altium 你是否曾经收到过Altium …...

Noto字体终极指南:如何免费获得900+语言支持的完整字体解决方案

Noto字体终极指南&#xff1a;如何免费获得900语言支持的完整字体解决方案 【免费下载链接】noto-fonts Noto fonts, except for CJK and emoji 项目地址: https://gitcode.com/gh_mirrors/no/noto-fonts 想要彻底告别网页和应用中的"豆腐块"乱码问题吗&…...

Reset Windows Update Tool:5分钟快速修复Windows更新问题的终极指南 [特殊字符]

Reset Windows Update Tool&#xff1a;5分钟快速修复Windows更新问题的终极指南 &#x1f680; 【免费下载链接】Reset-Windows-Update-Tool Troubleshooting Tool with Windows Updates (Developed in Dev-C). 项目地址: https://gitcode.com/gh_mirrors/re/Reset-Windows-…...

Python OCR实战:pytesseract高级配置与场景化应用指南

1. 为什么需要pytesseract高级配置&#xff1f; 第一次用pytesseract做OCR识别时&#xff0c;我直接调用了最简单的image_to_string()方法。结果遇到模糊图片时识别率惨不忍睹&#xff0c;处理表格文本时更是错漏百出。后来才发现&#xff0c;Tesseract引擎提供了20种参数配置组…...

Ostrakon-VL 人工智能扫描终端在运维监控中的应用:日志仪表盘图像识别

Ostrakon-VL 人工智能扫描终端在运维监控中的应用&#xff1a;日志仪表盘图像识别 1. 运维监控的痛点与解决方案 想象一下这样的场景&#xff1a;凌晨3点&#xff0c;运维工程师小王被电话惊醒&#xff0c;某个核心业务系统出现异常。他匆忙打开电脑&#xff0c;面对的是几十…...

Ostrakon-VL构建智能相册:基于内容的照片自动分类与搜索

Ostrakon-VL构建智能相册&#xff1a;基于内容的照片自动分类与搜索 1. 智能相册效果惊艳展示 想象一下&#xff0c;你的手机里有上万张照片&#xff0c;想找"去年夏天在海边拍的那张有狗狗和夕阳的照片"。传统相册只能靠记忆翻找&#xff0c;而基于Ostrakon-VL的智…...

TypeScript图算法教程:Dijkstra、Bellman-Ford等最短路径算法实战

TypeScript图算法教程&#xff1a;Dijkstra、Bellman-Ford等最短路径算法实战 【免费下载链接】TypeScript Algorithms and Data Structures implemented in TypeScript for beginners, following best practices. 项目地址: https://gitcode.com/gh_mirrors/type/TypeScript…...

即时通讯平台开发:iOS工程师的视角

引言 即时通讯(IM)平台在现代企业中扮演着核心角色,支撑着团队协作、客户服务和业务运营。作为iOS开发工程师,我们不仅需要精通移动端技术,还需兼顾PC端开发,尤其在跨平台框架如Electron的应用中。本文将从技术角度深入探讨IM平台的功能开发、架构优化、性能调优及新技术…...