MySQL——视图(二)视图管理(2)在单表上创建视图

本节将通过具体的案例来讲解如何在单表上创建视图。

例如,在 student 表上创建 view_stu.视图。

在创建视图之前需要先创建一个数据库 chapter07,创建数据库的 SQL 语句如下所示:

sql 复制代码
CREATE DATABASE chapter07;

选择使用数据库 chapter07,SQL语句如下:

sql 复制代码
mysql> USE chapter07;
Database changed

在数据库中创建一个表 student 用于存储学生信息,创建 student 表的 SQL 语句如下所示:

sql 复制代码
mysql> CREATE TABLE student(
    -> s_id INT(3),
    -> name VARCHAR(20),
    -> math FLOAT,
    -> chinese FLOAT
    -> );
Query OK, 0 rows affected, 1 warning (0.01 sec)

使用 INSERT 语句向 student 表中插人数据,SQL语句如下所示:

sql 复制代码
INSERT INTO student(s_id,name,math,chinese) VALUES(1,'Tom',80,78);
INSERT INTO student(s_id,name,math,chinese) VALUES(2,'Jack',70,80);
INSERT INTO student(s_id,name,math,chinese) VALUES(3,'Lucy',97,95);

在上述 SQL语句执行成功后,会在 student 表中添加三条数据。为了验证数据是否添加成功,使用 SELECT 语句查看 student 表中的数据,查询结果如下所示:

sql 复制代码
mysql> SELECT * FROM student;
+------+------+------+---------+
| s_id | name | math | chinese |
+------+------+------+---------+
|    1 | Tom  |   80 |      78 |
|    2 | Jack |   70 |      80 |
|    3 | Lucy |   97 |      95 |
+------+------+------+---------+
3 rows in set (0.00 sec)

从查询结果可以看出,student表中成功地添加了三条记录。接下来创建 student 表的视图,创建语句如下所示:

sql 复制代码
mysql> CREATE VIEW view_stu As SELECT math,chinese,math+chinese FROM student;
Query OK, 0 rows affected (0.00 sec)

上述 SQL语句执行成功后,会生成一个 view_stu 视图,接下来使用 SELECT 语句查看 view stu 视图,查询结果如下所示:

sql 复制代码
mysql>  SELECT * FROM view_stu;
+------+---------+--------------+
| math | chinese | math+chinese |
+------+---------+--------------+
|   80 |      78 |          158 |
|   70 |      80 |          150 |
|   97 |      95 |          192 |
+------+---------+--------------+
3 rows in set (0.00 sec)

从查询结果可以看出,view stu视图创建成功,并且重新定义了一个用于计算数学成绩和语文成绩之和的 math+chinese 字段。在默认情况下,创建的视图字段名称和基本表的字段名称是一样的,但是也可以根据实际的需要指定视图字段的名称。

例如,在 student 表上创建一个名为 view_stu2 的视图,自定义字段名称,SQI语句如下所示:

sql 复制代码
mysql> CREATE VIEw view_stu2(math,chin,sum) AS SELECT math,chinese,math+chinese FROM student;
Query OK, 0 rows affected (0.00 sec)

上述 SQL语句执行成功后,会生成一个名为 view_stu2 的视图,接下来使用SELECT 语句查看 view_stu2 视图,查询结果如下所示:

sql 复制代码
mysql> SELECT * FROM view_stu2;
+------+------+------+
| math | chin | sum  |
+------+------+------+
|   80 |   78 |  158 |
|   70 |   80 |  150 |
|   97 |   95 |  192 |
+------+------+------+
3 rows in set (0.01 sec)

从查询结果可以看出,虽然 view_stu 和 view_stu2 两个视图中的字段名称不同,但是数据却是相同的。这是因为这两个视图引用的是同一个表中的数据,并且创建视图的"AS SELECT math,chinese,math+chinese"条件语句相同。在实际开发中,用户可以根据自己的需要通过使用视图的方式获取基本表中自己需要的数据,这样既能满足用户的需求,也不需要破坏基本表原来的结构,从而保证了基本表中数据的安全性。

相关推荐
sunnyday042620 分钟前
MyBatis XML映射文件中的批量插入和更新
xml·java·mysql·mybatis
浪九天25 分钟前
Orcale、MySQL中参数类型的详解和运用场景(不带示例)
数据库·mysql·oracle
程序员阿鹏27 分钟前
jdbc批量插入数据到MySQL
java·开发语言·数据库·mysql·intellij-idea
计算机毕设指导62 小时前
基于SpringBoot的城乡商城协作系统【附源码】
java·spring boot·后端·mysql·spring·tomcat·maven
橘猫云计算机设计2 小时前
基于Django的购物商城平台的设计与实现(源码+lw+部署文档+讲解),源码可白嫖!
java·数据库·spring boot·后端·django
2501_903238653 小时前
Spring Boot日志配置与环境切换实战
数据库·spring boot·后端·个人开发
梓沂3 小时前
审计级别未启用扩展模式导致查询 DBA_AUDIT_TRAIL 时 SQL_TEXT 列为空
数据库·sql·dba
Smile丶凉轩3 小时前
数据库面试知识点总结
数据库·c++·mysql
RainbowSea4 小时前
9-1. MySQL 性能分析工具的使用——last\_query\_cost,慢查询日志
数据库·sql·mysql
Sui_Network4 小时前
Sui 如何支持各种类型的 Web3 游戏
大数据·数据库·人工智能·游戏·web3·区块链