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

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

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

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

  视图也存在一些缺点,主要如下。
  ● 性能: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. IdentityServer Topics(1)- 启动说明

    启动 IdentityServer的启动是中间件和服务的组合来实现的. 所有配置都在你的启动类(Startup.cs)中完成. 配置服务 通过以下方式调用将IdentityServer服务添加到DI系 ...

  2. [PHP] 编译构建最新版PHP源码

    获取最新PHP代码git clone https://git.php.net/repository/php-src.git构建编译环境apt-get install build-essential 编 ...

  3. web.xml解析

    常用元素及含义 <!-- standalone 定义了外部定义的 DTD 文件的存在性,有效值是 yes和 no --> <?xml version="1.0" ...

  4. java 多线程 Callable -- 分段处理一个大的list 然后再合并结果

    本文代码参考 http://bbs.csdn.net/topics/391070227?page=1 下面是贴出的代码: public void dealListWithMutiThread(){ L ...

  5. junit测试模板 unit-test

    一个项目能否发布上线,重要的环节就是测试.经过集成测试.性能测试.压力测试等不断循环的测试过后依据测试报告来确定上线.这些由专业的测试人员来完成,因此会导致程序开发者对自身的单元测试的弱化.若在代码中 ...

  6. 部署java项目到阿里云服务器(centos7版本)

    一.搭建环境 1.搭建java环境(64位) 一.准备压缩包,rpm包或者tar包,将其上传到阿里云对应的文件夹(我用的工具是WinSCP,百度一下就有下载资源) 二.若是rpm包,可以通过 rpm ...

  7. 项目架构开发:数据访问层之UnitOfWork (补充)

    应lisansi同学回复(项目架构开发:数据访问层之UnitOfWork)要求,补上Dapper的DbContext实现 using Dapper.Contrib.Extensions; using ...

  8. visualMap组件横向展示

  9. 最小生成树&最短路基础算法总结

    [最短路问题] 解决最短路问题有以下算法:Dijkstra算法,Bellman-Ford算法,Floyd算法,和SPFA算法和启发式搜索算法A*; 每个算法都有它的特点可以解决某些特定的问题,例如:F ...

  10. SSH私用私钥登陆

    1.导入私钥,将私钥文件放到当前登陆用户目录下的.ssh目录下 2.指定私钥登陆,ssh -i .ssh/ssh_rsa  root@target.com 如果出现了下面这种情况 这是因为私钥文件权限 ...