视图是从一个或多个表中导出来的表,是一种虚拟存在的表。
视图就像一个窗口,通过这个窗口可以看到系统专门提供的数据。
这样,用户可以不用看到整个数据库中的数据,而之关心对自己有用的数据。
数据库中只存放了视图的定义,而没有存放视图中的数据,这些数据存放在原来的表中。
使用视图查询数据时,数据库系统会从原来的表中取出对应的数据。
视图中的数据依赖于原来表中的数据,一旦表中数据发生改变,显示在视图中的数据也会发生改变。
1.使操作简单化,可以对经常使用的查询定义一个视图,使用户不必为同样的查询操作指定条件
2.增加数据的安全性,通过视图,用户只能查询和修改指定的数据。
3.提高表的逻辑独立性,视图可以屏蔽原有表结构变化带来的影响。
select s.id,s.name, g.score from t_stu s left join t_grade g on s.id=g.sid; 需求;创建视图 create view view_stu (id,name,score) as select s.id,s.name,g.score from t_stu s left join t_grade g on s.id=g.sid ;
需求:查询视图
SELECT * FROM view_stu ;
需求 :修改视图 CREATE OR REPLACE VIEW view_stu(name ,score) as select s.name,
g.score from t_stu s left join t_grade g on s.id=g.sid ;
需求:修改视图 alter VIEW view_stu(id ,name ,score) as select s.id, s.name,
g.score from t_stu s left join t_grade g on s.id=g.sid ;
需求:更新视图(最终修改的是基本表) update view_stu set score =100 where name ='zs';
select * from t_grade ;
需求:删除视图 drop view view_stu ;