MySQL之视图&外连接、内连接和子查询的使用

目录

一. 视图

        1.1 含义

        1.2 视图的基本语法

        1.3 视图的实操

二. 外连接、内连接和子查询的使用

        2.1 SQL脚本

        2.2 使用外连接、内连接和子查询进行解答

三. 思维导图


一. 视图

        1.1 含义

        视图(view)是一种虚拟存在的表,是一个逻辑表,视图中的数据并不在数据库中实际存在。 行和列数据来自我们定义视图的查询中使用的表,并且是在使用视图时动态生成的。作为一个select语句保存在数据字典中的,通俗的讲,视图只保存了查询的SQL逻辑,不保存查询结果。所以我们在创建视图的时候,主要的工作就落在创建这条SQL查询语句上。

        1.2 视图的基本语法

  • 创建视图
create view 视图名
as
查询语句;
  • 修改视图
#方式一
create or replace view 视图名
as
查询语句;
 
#方式二
alert view 视图名
as
查询语句;
  • 查看视图
#查看视图相关字段
DESC 视图名;

#查看视图相关语句
SHOW CREATE VIEW 视图名;
  • 删除视图
drop view 视图名,视图名,...;

        1.3 视图的实操

  • 创建视图
CREATE VIEW v_student_score AS SELECT
s.*,
sc.cid,
sc.score 
FROM
	t_mysql_student s,
	t_mysql_score sc 
WHERE
	s.sid = sc.sid;

  • 查看视图

查看视图相关字段:

DESC v_student_score;

查看视图创建的相关语句:

SHOW CREATE VIEW v_student_score;

  • 删除视图
DROP VIEW v_student_score;

可以看见我们之前创建的视图已经没有了: 

二. 外连接、内连接和子查询的使用

        2.1 SQL脚本

/*
 Navicat Premium Data Transfer

 Source Server         : localhost
 Source Server Type    : MySQL
 Source Server Version : 80018
 Source Host           : localhost:3306
 Source Schema         : mybatis_ssm

 Target Server Type    : MySQL
 Target Server Version : 80018
 File Encoding         : 65001

 Date: 04/07/2023 23:53:33
*/

SET NAMES utf8mb4;
SET FOREIGN_KEY_CHECKS = 0;

-- ----------------------------
-- Table structure for t_mysql_course
-- ----------------------------
DROP TABLE IF EXISTS `t_mysql_course`;
CREATE TABLE `t_mysql_course`  (
  `cid` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '课程编号',
  `cname` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '课程名称',
  `tid` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '教师编号',
  PRIMARY KEY (`cid`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci COMMENT = '课程信息表' ROW_FORMAT = Dynamic;

-- ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值