您的当前位置:首页>全部文章>文章详情

【MySql】MySQL表的内外连接和视图

CrazyPanda发表于:2024-01-30 20:45:27浏览:367次TAG:



一、表的内外连接

表的连接分为内连和外连。

1. 内连接

内连接实际上就是利用 where 子句对两种表形成的笛卡尔积进行筛选,我们前面学习的查询都是内连接,也是在开发过程中使用的最多的连接查询。

语法:

			select 字段 from 表1 inner join 表2 on 连接条件 and 其他条件;

例如:

  • 显示 JAMES 的名字和部门名称

用前面的写法直接用笛卡尔积:

			select ename, dname from emp, dept where emp.deptno=dept.deptno and ename='JAMES';

用标准的内连接写法:

select ename, dname from emp
    -> inner join dept
    -> on emp.deptno = dept.deptno
    -> and ename = 'JAMES';

01.png

2. 外连接

外连接分为左外连接和右外连接。

(1)左外连接

如果联合查询,左侧的表完全显示,我们就称作是左外连接。

语法:

			select 字段名 from 表名1 left join 表名2 on 连接条件;

例如,先创建两张表:

学生表,并插入数据:

01.png

成绩表,并插入数据:

01.png

接下来要做的:

  • 查询所有学生的成绩,如果这个学生没有成绩,也要将学生的个人信息显示出来

我们使用左外连接,将学生表的信息在左边显示,当左边表和右边表没有匹配时,也会显示左边表的数据:

			select * from stu left join exam on stu.id = exam.id;

01.png

(2)右外连接

如果联合查询,右侧的表完全显示我们就说是右外连接。

语法:

			select 字段 from 表名1 right join 表名2 on 连接条件;
  • 对 stu 表和 exam 表联合查询,把所有的成绩都显示出来,即使这个成绩没有学生与它对应,也要显示出来

      		select * from stu right join exam on stu.id=exam.id;
    • 1

01.png

接下来我们继续使用员工表进行练习:

  • 列出部门名称和这些部门的员工信息,同时列出没有员工的部门

方法一:

			select d.dname, e.* from dept d left join emp e on d.deptno = e.deptno;

01.png

方法二:

			select d.dname, e.* from emp e right join dept d on d.deptno = e.deptno;

01.png

3. 练习

  1. Leetcode:分数排名

  2. Leetcode:换座位

二、视图

1. 视图的使用

我们上面所使用的内外连接所生成的表都是一个临时表,假设我们频繁地使用该表,那么有没有办法将这个临时表转化为虚拟表呢?

视图就是一个虚拟表,其内容由查询定义。同真实的表一样,视图包含一系列带有名称的列和行数据。视图的数据变化会影响到基表,基表的数据变化也会影响到视图。

  • 创建视图

      			create view 视图名 as select语句;


例如我们使用内连接:

01.png

而创建视图:

01.png

我们会发现多了一个表结构,我们查看该表:

01.png

如上,我们发现该表和我们用内连接的结果一样。

  • 修改了视图,对基表数据有影响

01.png

  • 修改了基表,对视图有影响

01.png

  • 删除视图

      			drop view 视图名;
    • 1

2. 视图规则和限制

  • 与表一样,必须唯一命名(不能出现同名视图或表名);

  • 创建视图数目无限制,但要考虑复杂查询创建为视图之后的性能影响;

  • 视图不能添加索引,也不能有关联的触发器或者默认值;

  • 视图可以提高安全性,必须具有足够的访问权限;

  • order by 可以用在视图中,但是如果从该视图检索数据 select 中也含有 order by ,那么该视图中的 order by 将被覆盖;

  • 视图可以和表一起使用。


原文链接https://blog.csdn.net/YoungMLet/article/details/135061496

猜你喜欢

【MySql】mysql 将数据库中的所有表结构和数据 导入到另一个库(亲测有效)
一、问题描述在本地开发一个功能,需要结合具体数据测试代码是否正确,但服务器上的数据不可随便修改。此时则需要将服务器上某个数据库的表批量导入到本地、而后进行测试。将数据库db1中的所有表及数据(如table1、table2),批量导入到另一个数据库db2中。二、解决方案刚开始自己一直尝试用DataGrip、Navicat的sql/csv格式导入导出,总有错误或者遗漏,比如报错中止、50张表却只导入32张等,可能是操作方式有误或者数据格式有问题。也试过用sql语句,但仍失败。经查阅资料、尝试多次,终
发表于:2024-01-30 浏览:371 TAG:
【MySql】mysql explain 查询详解
MySQL 的 EXPLAIN 语句是一个强大的工具,用于分析和优化查询的执行计划。它提供了关于 MySQL 如何执行查询的详细信息,包括表的访问顺序、访问方法、使用的索引、连接类型等。以下是 EXPLAIN 查询的详细解释:
发表于:2025-02-21 浏览:69 TAG: #mysql
【MySql】如何进行数学计算、字符串处理和条件判断?
文章目录如何进行数学计算、字符串处理和条件判断?数学函数字符串函数条件判断函数总结如何进行数学计算、字符串处理和条件判断?MySQL 提供了很多功能强大,而且使用起来非常方便的函数,包括数学函数、字符串处理函数和条件判断函数等。在很多场景中 ,我们都会用到这些函数,比如说,在超市项目的实际开发过程中,会有这样的需求:会员积分的规则是一元积一分,不满一元不积分,这就要用到向下取整的数学函数 floor();在打印小票的时候,收银纸的宽度是固定的,怎么才能让打印的结果清晰而整齐呢?这个时候,就要用到
发表于:2023-12-07 浏览:377 TAG:
【MySql】MySql给数据库表添加新字段
要在MySQL中添加新字段,您可以使用ALTER TABLE语句。以下是添加新字段的基本语法:ALTER TABLE table_name ADD column_name datatype;其中:table_name 是您要在其中添加新字段的表的名称。column_name 是新字段的名称。datatype 是新字段的数据类型。例如,VARCHAR、INT或DOUBLE等。以下是一个示例ALTER TABLE语句,演示如何向名为user的表添加一
发表于:2024-09-03 浏览:241 TAG: #mysql
【MSQL】MATCH() AGAINST()全文搜索
这个问题是关于MySQL的全文搜索查询。MATCH() AGAINST() 是MySQL全文搜索的一部分。问题中的代码是在查询中使用MATCH() AGAINST(),但是使用方式有一些问题。首先,MATCH() 函数的参数应该是一个字段名,而不是一个字段值。其次,AGAINST 子句后面应该是要搜索的字符串,并且这个字符串需要被单引号包围。在布尔全文搜索模式下,你需要使用一些特殊的操作符来表示搜索的重要性或条件。例如,+表示一个词必须存在,而 - 表示一个词必须不存在。SELECT 
发表于:2024-07-26 浏览:235 TAG:
【MySQL】mysql百万级数据表翻页查询特别慢的优化方式
最近遇到了mysql百万级数据表翻页查询特别慢的问题,查询第一页的时候,特别快,翻页跨度特别大的时候,翻页查询就会特别慢
发表于:2024-11-14 浏览:251 TAG: #mysql
【MySQL】 复合查询 | 内外连接
文章目录1. 复合查询unionunion all单行子查询多行子查询多列子查询in关键字all关键字any关键字多表笛卡尔积自连接在where子句使用子查询在from子句中使用子查询合并查询2. 内连接3. 外连接左外连接右外连接1. 复合查询多表笛卡尔积显示雇员名、雇员工资以及所在部门的名字由于员工 信息属于 emp表 而所在部门名字属于 dept表 数据来自不同的表,所以需要进行多表查询表示从 emp (员工表) 和dept (部门表)
发表于:2023-11-30 浏览:858 TAG:
【MySql】Centos7 安装 MySQL5.7 步骤
Centos7 安装 MySQL5.7 步骤(一)、使用yum源方式安装4.1 开启mysql的远程访问权限4.2 为firewalld添加开放端口33064.3 远程连接测试3.1 启动mysql并查看状态3.2 获取临时密码3.3 登录mysql3.4 修改登录密码2.1 下载mysql的yum源配置2.2 安装mysql的yum源2.3 使用yum方式安装mysql2.3.1 安装过程中报错解决1、卸载系统自带 mariadb2、下载并安装MySQL官方的 Yum3、使用并设置mysql4
发表于:2023-11-30 浏览:2098 TAG:
【MySQL】MySQL数据库CPU飙升到100%解决方案
1、定位cpu问题所在当cpu飙升到100%时,先用操作系统命令top命令观察是不是mysqld占用导致的,如果不是,找出占用高的进程,并进行相关处理。2、查看慢查询日志进入mysql命令行mysql -h主机地址 -u用户名 -p用户密码1查看慢查询SQL是否启用:ON是开启,OFF是关闭。 show variables like ‘log_slow_queries’;开启慢查询日志 set global log_slow_queries = on;3、使用sho
发表于:2024-07-17 浏览:247 TAG:
【MySql】MySQL表的内外连接和视图
内外连接一、表的内外连接(1)左外连接(2)右外连接1. 内连接2. 外连接3. 练习二、视图1. 视图的使用2. 视图规则和限制一、表的内外连接表的连接分为内连和外连。1. 内连接内连接实际上就是利用 where 子句对两种表形成的笛卡尔积进行筛选,我们前面学习的查询都是内连接,也是在开发过程中使用的最多的连接查询。语法: select 字段 from 表1 inner join 表2 on 连接条件&nbs
发表于:2024-01-30 浏览:368 TAG: