视图是一个虚拟表,是sql的查询结果,其内容由查询定义。同真实的表一样,视图包含一系列带有名称的列和行数据,在使用视图时动态生成。视图的数据变化会影响到基表,基表的数据变化也会影响到视图[insert update delete ] 创建视图需要create view 权限,并且对于查询涉及的列有select权限;使用create or replace 或者 alter修改视图,那么还需要改视图的drop权限。
创建视图的语法:
create view 视图名 as select 字段名 from 表名
例如:
(1).第一类:create view v as select * from table(2).第二类:create view v as select id,name,age from table
(3).第三类:create view v[vid,vname,vage] as select id,name,age from table
如果涉及到数据量过大,业务逻辑需要跨表查询等等也可建立一个跨表的视图,有三种情况:
一、基于同一数据库
这种情况较为简单,只需简单的一行sql命令,如下:
create view v as (select * from table1) union all (select * from table2)
二、基于不同数据库
这种情况只比上面的sql语句多一个数据库的名字,如下:
create view 数据库1.v as (select * from 数据库1.table1) union all (select * from 数据库2.table2)
或
create view 数据库2.v as (select * from 数据库1.table1) union all (select * from 数据库2.table2)
如果执行第一个sql将在数据库1下建立视图,反之亦然;
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)