MySQL视图

文章目录

MySQL系列:

初识MySQLMySQL常用数据类型和表的操作增删改查(CRUD)操作(总),数据库约束数据库设计SQL联合查询

1. 视图的核心概念

虚拟表:视图的结构和内容由SELECT语句定义,不独立存储数据。

动态数据:视图的数据在查询时实时生成,反映基表的最新状态。

逻辑抽象:隐藏底层表的复杂性,提供简化的数据访问接口。

2. 视图的用途

简化复杂查询:将多表连接、子查询等复杂操作封装成视图,用户直接查询视图即可。

数据安全:通过视图限制用户访问敏感字段(如隐藏薪资列)。

逻辑独立性:修改基表结构时,可调整视图定义以保持应用层兼容。

统一数据视角:为不同用户或应用提供定制化的数据子集。

sql 复制代码
create table student(
id bigint primary key auto_increment,
name varchar(20)not null,
sno varchar(10) not null,
age int default 18,
gender tinyint(1),
enroll_date date,
class_id bigint,
foreign key(class_id) references class(id)
);
insert into student (name, sno, age, gender, enroll_date, class_id) values 
('唐三藏', '100001', 18, 1, '1986-09-01', 1),
('孙悟空', '100002', 18, 1, '1986-09-01', 1),
('猪悟能', '100003', 18, 1, '1986-09-01', 1),
('沙悟净', '100004', 18, 1, '1986-09-01', 1),
('宋江', '200001', 18, 1, '2000-09-01', 2),
('武松', '200002', 18, 1, '2000-09-01', 2),
('李逹', '200003', 18, 1, '2000-09-01', 2),
('不想毕业', '200004', 18, 1, '2000-09-01', 2);

3.创建视图

语法:

sql 复制代码
CREATE VIEW view_name [(column_list)] AS select_statement
sql 复制代码
create view v_student as select * from student s where s.id<4;

4.修改数据

sql 复制代码
update student set student.name='李白' where student.id=1;

修改真实表的数据会影响视图

修改视图数据也会影响真实表

5.删除视图

语法:

sql 复制代码
drop view view_name;

6. 视图的优点

  1. 简单性:视图可以将复杂的查询封装成⼀个简单的查询。例如,针对⼀个复杂的多表连接查询,可
    以创建⼀个视图,⽤⼾只需查询视图⽽⽆需了解底层的复杂逻辑。
  2. 安全性:通过视图,可以隐藏表中的敏感数据。例如,⼀个系统的⽤⼾表中,可以创建⼀个不包含
    密码列视图,普通⽤⼾只能访问这个视图,⽽不能访问原始表。
  3. 逻辑数据独⽴性:视图提供了⼀种逻辑数据独⽴性,即使底层表结构发⽣变化,只需修改视图定
    义,⽽⽆需修改依赖视图的应⽤程序。使⽤到应⽤程序与数据库的解耦
  4. 重命名列:视图允许⽤⼾重命名列名,以增强数据可读性
相关推荐
Anarkh_Lee19 小时前
【小白也能实现智能问数智能体】使用开源的universal-db-mcp在coze中实现问数 AskDB智能体
数据库·人工智能·ai·开源·ai编程
橘子1319 小时前
MySQL用户管理(十三)
数据库·mysql
Dxy123931021619 小时前
MySQL如何加唯一索引
android·数据库·mysql
我真的是大笨蛋19 小时前
深度解析InnoDB如何保障Buffer与磁盘数据一致性
java·数据库·sql·mysql·性能优化
怣5019 小时前
MySQL数据检索入门:从零开始学SELECT查询
数据库·mysql
shengli72219 小时前
机器学习与人工智能
jvm·数据库·python
2301_7657031419 小时前
Python迭代器(Iterator)揭秘:for循环背后的故事
jvm·数据库·python
倔强的石头10620 小时前
关键信息基础设施的数据库选型:高可用、全链路安全与平滑替代的技术实践
数据库·安全·金仓数据库
人道领域20 小时前
javaWeb从入门到进阶(SpringBoot事务管理及AOP)
java·数据库·mysql
煎蛋学姐20 小时前
SSM音乐播放软件的开发与实现7g5j0(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架·javaweb 开发·前后端开发