视图是从一个或者多个表中查询数据的另一种方式。利用视图可以集中、简化定制数据库,同时还能保障安全。

  视图其结构和数据是建立在对应的查询基础上的。和表一样,视图也是包括几个被定义的数据列和多个数据行,但本质而言,这些数据列和数据行来源于他所引用的表。所以试图不是真是存在的基础表,而是一张虚表。我们也可以对师徒中的数据进行增删查改(有一定限制)。

  当然视图也有一定的优缺点:

  ● 简单性。视图不仅可以简化用户对数据的理解,也可以简化他们的操作。那些被经常使用的查询可以被定义为视图,从而使用户不必为以后的操作每次都指定全部的条件。
  ● 安全性。通过视图用户只能查询和修改他们所能见到的数据。数据库中的其他数据则既看不见也取不到。数据库授权命令可以使每个用户对数据库的检索限制到特定的数据库对象上,但不能授权到数据库特定行和特定的列上。通过视图,用户可以被限制在数据的不同子集上。
  ● 逻辑数据独立性。视图可以使应用程序和数据库表在一定程度上独立。如果没有视图,应用一定是建立在表上的。有了视图之后,程序可以建立在视图之上,从而程序与数据库表被视图分割开来。

  视图也存在一些缺点,主要如下。
  ● 性能:SQL Server必须把视图的查询转化成对基本表的查询,如果这个视图是由一个复杂的多表查询所定义,那么,即使是视图的一个简单查询,SQL Server也把它变成一个复杂的结合体,需要花费一定的时间。
  ● 修改限制:当用户试图修改视图的某些行时,SQL Server必须把它转化为对基本表的某些行的修改。对于简单视图来说,这是很方便的,但是,对于比较复杂的视图,可能是不可修改的。

  一、为整表创建视图并查看其信息

--------创建一个与Student表对应的视图
CREATE VIEW Student_view
AS
select * from Student --------查询这个视图
select * from student_view

  二、为视图创建视图并查看其信息

--------为Student_view视图创建一个所有男同学的视图Boy_View
create view Boy_View
as
select * from Student_view where Ssex='男' --------查询这个视图
select * from Boy_View

  

  三、为列创建视图并查看其信息

--------为列创建视图并查看其信息
create view NameAge_View
as
select Sname,Sage from Student --------查询这个视图
select * from NameAge_View

  四、为表创建具有不同字段名的视图并查看其信息

--------为表创建具有不同字段名的视图并查看其信息
--------Student表中所有男同学的姓名和性别
CREATE VIEW NewCloumnName_View(Name,Age)
AS
select Sname,Ssex from Student
where Ssex='男' --------查询这个视图
select * from NewCloumnName_View

   五、为表创建具有不同字段名的视图并查看其信息

--------利用视图简化表的链接
--------Student,Teacher,Course表关联显示,学生的语文成绩
CREATE VIEW join_View(XM,KC,CJ)
AS
select Sname,Cname,score from Student,Course,Sc
where Sc.S#=Student.S#
and Sc.C#=Course.C# and Course.Cname='语文' --------查询这个视图
select * from join_View

  六、修改视图

-------修改join_View视图中的数据
---------将王五同学的成绩改成999999
update join_View set CJ='' where XM='王五' --------查询这个视图
select * from join_View -----数据已经变为999999
--------查询原表数据
select Sname,Cname,score from Student,Course,Sc
where Sc.S#=Student.S#
and Sc.C#=Course.C# and Course.Cname='语文' -----数据已经变为999999

  网上有些人说,视图只能查看删除,不能修改,但是个人实际操作发现,修改后,原表数据会跟着修改。

  对于以上就是对视图的讲解基本操作,其中AS 后面的SQL语句是可以添加任意条件查询的,复杂查询就不做操作了,可以自行扩展。

  七、删除销毁视图

DROP VIEW join_View

  删除视图对实际表中的数据是不会有影响的。

  八、视图的存放位置

  

   九、注意事项

  

  使用视图的几点原则:

  1. 和表一样,视图也有唯一的名字。不仅视图之间不允许 有相同的名字,并且视图与表业不允许拥有相同的名字。
  2. 视图的创建 个数不受限制,用户可以创建任意多个视图。
  3. 用户要创建试图,必须从数据库管理员那里得到权限。
  4. 视图可以嵌套,即可以创建视图的视图。(也就是第二条)
  5. 一些数据库管理系统(SQL Service)禁止用户在查询语句中使用Order By字句。(也就是第九条)

Sql Server的艺术(一) 视图的增删查改的更多相关文章

  1. CATransition:视图替换动画:子视图的增删查改

    CATransition通常用于通过CALayer控制UIView内子控件的过渡动画,比如删除子控件,添加子控件,切换两个子控件等. 用于子视图的增删查改:

  2. SQL Server索引 - 索引(物化)视图 <第九篇>

    一.索引视图基本概念 索引视图实际上是一种将一组唯一值“物化”为群集索引形式的视图,所为物化就是几乎和表一样,其数据也是会存储一份的(会占用硬盘空间,但是查询速度快,例如可以将count(),sum( ...

  3. SQL Server 表的管理_关于数据增删查改的操作的详解(案例代码)

    SQL Server 表的管理_关于数据增删查改的操作的详解(案例代码)-DML 1.SQL INSERT INTO 语句(在表中插入) INSERT INTO 语句用于向表中插入新记录. SQL I ...

  4. SQL Server 表的管理_关于表的操作增删查改的操作的详解(案例代码)

    SQL Server 表的管理_关于表的操作增删查改的操作的详解(案例代码) 概述: 表由行和列组成,每个表都必须有个表名. SQL CREATE TABLE 语法 CREATE TABLE tabl ...

  5. sql server中如何修改视图中的数据?

    sql server中如何修改视图中的数据? 我做个测试,视图的数据有标记字段时,如果是这种方式(0 as FlagState),是无法修改的 --创建视图语句 --- create view V_E ...

  6. SQL Server跨服务器建立视图

    create view View_AppCus as select dwmch,zjm from ksoa.dbo.mchk SQL Server跨服务器操作经常需要用到,下面就为你介绍的是SQL S ...

  7. 常用SQL语句(增删查改、合并统计、模糊搜索)

    转自:http://www.cnblogs.com/ljianhui/archive/2012/08/13/2695906.html 常用SQL语句 首行当然是最基本的增删查改啦,其中最重要的是查. ...

  8. EF各版本增删查改及执行Sql语句

    自从我开始使用Visual Studio 也已经经历了好几个版本了,而且这中间EF等框架的改变也算是比较多的.本篇文章记录下各个版本EF执行Sql语句和直接进行增删查改操作的区别,方便自己随时切换版本 ...

  9. EF增删查改加执行存储过程和sql语句,多种方法汇总

    ActionUrl c = new ActionUrl() { ActionName="test", RequestUrl="/123/123", SubTim ...

随机推荐

  1. 定义一个数,它可能为正 也可能为负 var num = Math.pow(-1,parseInt(Math.random() * 2) + 1);

    // 定义一个随机数范围从0 ~页面宽度 var x = parseInt(Math.random() * myCanvas.width); // 定义一个随机数 范围从0 ~页面高度 var y = ...

  2. 10、ABPZero系列教程之拼多多卖家工具 拼团提醒逻辑功能实现

    上篇文章已经封装好了类库,现在继续实现功能,在ABPZero框架的基础上来实现一个完整的功能. Redis缓存 编写功能前先在本机安装好Redis,需要用到Redis做缓存,以下分享2个Windows ...

  3. 七牛php-sdk使用-在线打包

    如果需要将空间中的多个文件,打包成一个压缩文件,该怎么做,不需要自己本地打包好再上传,七牛已经为我们提供了这项服务. 命令:mkzip/2/url/xx/alias/xxx; 不仅可以将文件打包,还可 ...

  4. JavaSE(十一)之异常处理详解

    一.异常概述 在我们日常生活中,有时会出现各种各样的异常,例如:职工小王开车去上班,在正常情况下,小王会准时到达单位.但是天有不测风云,在小王去上班时,可能会遇到一些异常情况,比如小王的车子出了故障, ...

  5. bzoj:1584: [Usaco2009 Mar]Cleaning Up 打扫卫生

    Description 有N头奶牛,每头那牛都有一个标号Pi,1 <= Pi <= M <= N <= 40000.现在Farmer John要把这些奶牛分成若干段,定义每段的 ...

  6. div排版+文档流+定位秘诀

    由于没有找到自己认为完整的关于普通流.浮动和绝对定位的中文文章,于是鼓起勇气决定自己来写篇. 在普通流中的 Box(框) 属于一种 formatting context(格式化上下文) ,类型可以是 ...

  7. Entity Framework Core 懒加载

    众所周知在EF 6 及以前的版本中,是支持懒加载(Lazy Loading)的,可惜在EF Core 并不支持,必须使用Include方法来支持导航属性的数据加载.不过现在EF Core的开发团队打算 ...

  8. oracle 11g体系结构

    1.数据库体系结构 1.1 数据库和实例的关系database server  = instance 实例 + database 数据库instance 实例  =内存 memory + 进程  pr ...

  9. TPshop学习(8)微信支付

    http://blog.csdn.net/phper8/article/details/76383415 学习内容: https://www.kancloud.cn/tpshop/thinkphp5/ ...

  10. iOS 注册页面 报错

    1.SpringBoard 无法启动应用程序(错误:-3) 方法:重启模拟器 2.