目录
一. 视图
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;
-- ---