想来想去,总想写写SQL Server方面的知识,像视图、存储过程,大数据量操作的优化等等。

先把基础的知识总结个遍先,然后再寻求更高更远的发展。这篇文章,将带大家来看看视图。

何谓视图,视图包含行和列,就像一个真实的表(虚表)。视图中的字段就是来自一个或多个数据库中真实的表中的字段。我们可以向视图添加 SQL 函数、WHERE 以及 JOIN 语句,我们也可以提交数据,就像这些来自于某个单一的表。

对于视图跟函数的区别,很多人都想知道,我也想知道,也上网查询了相关的内容,但是大多只是解释其概念,并没有区分明白。那么,就我学习到的内容,我也谈谈它们之间的区别。我认为视图跟内联表值函数比较接近(只是接近,但是不能取代)。不同于标量函数只能返回一个值,不同于多语句表值函数,可以有多条语句来返回表数据集。对于内联表值函数来讲,视图没有参数传递的方式。而对于视图来讲,它比内联表值函数多出一个WITH CHECK OPTION限制。WITH CHECK OPTION限制可看下文介绍。如果觉得本人总结得不好,欢迎大家拍砖。让思维碰撞出火花,让我们共同进步。

创建视图
CREATE VIEW <视图名> [(<列名>[,<列名>]....)]
AS
<子查询>
[WITH CHECK OPTION]

其中的[]为可选项,即可用可不用。WITH CHECK OPTION表示对视图进行UPDATE、INSERT和DELETE操作时要保证更新、插入和删除的行满足视图定义中的谓词条件(即子查询中的条件表达式)。

创建视图可通过下图右键的方式来创建,也可以在新建查询窗口里面写创建视图的语句。

CREATE VIEW [dbo].[VPerson](FName, FCity, FAge, FSalary)
AS
SELECT FName, FCity, FAge, FSalary
FROM dbo.T_Person
WHERE FAge=20
WITH CHECK OPTION

上面说了使用WITH CHECK OPTION表示对视图进行UPDATE、INSERT和DELETE操作时要保证更新、插入和删除的行满足视图定义中的谓词条件(即子查询中的条件表达式),如果不满足的话,会怎么样?我们来看看下面的例子:

UPDATE [dbo].[VPerson] SET FAGE=10 WHERE FAGE=20

报错如下:

试图进行的插入或更新已失败,原因是目标视图或者目标视图所跨越的某一视图指定了 WITH CHECK OPTION,而该操作的一个或多个结果行又不符合 CHECK OPTION 约束。
语句已终止。

使用WITH CHECK OPTION可以这么解释:通过视图进行的操作,必须也能通过该视图看到操作后的结果。

比如INSERT,那么加的这条记录在视图查询后必须可以看到。

比如UPDATE,修改完的结果也必须能通过该视图看到。

比如DELETE,只能删除视图里有显示的记录。

  INSERT INTO [dbo].[VPerson]([FName],[FCity],[FAge],[FSalary])
VALUES('Peter','SZ', 20,2000)

上面INSERT的例子如果FAge不是20的话,则跟上面UPDATE的报错一样。

 INSERT INTO [dbo].[VPerson]([FName],[FCity],[FSalary])
VALUES('Peter','SZ',2000)

因为视图[VPerson]使用了下面的语句,则对视图使用插入语句时,系统默认已经给FAage指定好了20这个条件值

WHERE FAge=20
WITH CHECK OPTION
 删除视图
  DROP VIEW <视图> [CASCADE];

其中的[]为可选项,即可用可不用。视图删除后视图的定义将从数据字典中删除。如果该视图上还导出了其他视图,则使用CASCADE级联删除语句,把该视图和由它导出的所有视图一起删除。

基本表删除后,由该基本表导出的所有视图(定义)没有被删除,但均已无法使用了。如果需要删除视图,则可以使用上面的DROP VIEW语句来删除。

  DROP VIEW [VPerson];

注:很奇怪,我使用了下面级联的删除语句,发现老是报错。查看了网上的一些资料,有人说没有级联的删除方式。不知道大伙知道不?

  DROP VIEW [VPerson] CASCADE;
关键字 'CASCADE' 附近有语法错误。
 视图作用

视图的作用,我转载博友(http://www.cnblogs.com/sunzhiyue/archive/2011/12/12/2284853.html )的内容。

第一点:使用视图,可以定制用户数据,聚焦特定的数据

解释:在实际过程中,公司有不同角色的工作人员。我们以销售公司为例的话,采购人员,可能需要一些与其有关的数据,而与他无关的数据,对他没有任何意义,我们可以根据这一实际情况,专门为采购人员创建一个视图,以后他在查询数据时,只需select * from view_caigou 就可以啦。 (当然拉,不会是叫人去装数据库客户端吧)

第二点:使用视图,可以简化数据操作

解释:我们在使用查询时,在很多时候我们要使用聚合函数,同时还要显示其它字段的信息,可能还会需要关联到其它表,这时写的语句可能会很长,如果这个动作频繁发生的话,我们可以创建视图,这样以后,我们只需要select * from view1就可以啦~,是不是很方便呀~

第三点:使用视图,基础表中的数据就有了一定的安全性

解释:因为视图是虚拟的,物理上是不存在的,只是存储了数据的集合,我们可以将基础表中重要的字段信息,可以不通过视图给用户,视图是动态的数据的集合,数据是随着基面表的更新而更新。同时,用户对视图,不可以随意的更改和删除,可以保证数据的安全性。

第四点:可以合并分离的数据,创建分区视图

解释:随着社会的发展,公司的业务量不断的扩大,一个大公司,下属都设有很多的分公司,为了管理方便,我们需要统一表的结构,定期查看各公司业务情况,而分别看各个公司的数据很不方便,没有很好的可比性,如果将这些数据合并为一个表格里,就方便多啦,这时我们就可以使用union关键字,将各分公司的数据合并为一个视图。

至此本文完。

SQL Server视图的更多相关文章

  1. 11、SQL Server 视图、数据库快照

    SQL Server 视图 什么是视图? 视图是一个虚拟的表,内容源于查询的结果集.只有当视图上建立了索引后,才会具体化. 视图可以筛选和处理数据,而不是直接访问基础表.如:创建一个视图,只展示源表中 ...

  2. 使用SQL Server视图的优缺点

    SQL Server视图我们经常会用的到,下面就为您介绍使用SQL Server视图的优缺点,希望可以对您SQL Server视图有更多的了解. 在程序设计的时候必须先了解视图的优缺点,这样可以扬长避 ...

  3. (4.22)sql server视图/索引视图概念

    (4.22)sql server视图 关键词:sql server视图.索引视图 SQL Server视图是由SQL语句组成的逻辑数据库对象.它也可以称为由SQL语句组成的虚拟表,该SQL语句可能包含 ...

  4. CodeSmith生成SQL Server视图的实体类脚本/对应的生成模板

    C#生成sql视图的实体类 using System;using System.Text;using CodeSmith.Engine;using SchemaExplorer;using Syste ...

  5. SQL SERVER视图对查询效率的提高

    SQL SERVER视图不仅可以实现许多我们需要的功能,而且对于SQL SERVER查询效率的提高也有帮助,下面一起来了解一下. 有两张数据表:A和B,其中A的记录为2万条左右,而B中的数据为200万 ...

  6. 通过 SQL Server 视图访问另一个数据库服务器表的方法

    今天项目经理跑过来对我大吼大叫说什么之前安排让我做一大堆接口为什么没做,我直接火了,之前明明没有这个事情…… 不过事情还要解决,好在两个项目都是用的sqlserver,可以通过跨数据库视图来快速解决问 ...

  7. 数往知来SQL SERVER 视图 触发器 <九>

    SQL server学习_视图 1.视图 视图其实是一张虚拟表,他是一张表的部分数据或多张表的综合数据(视图就是把SQL语句封装起来) 可以看做是一个结果集,但是不是一个结果集 视图不具备存储数据的能 ...

  8. SQL Server 视图

    视图实际上就是一个存储查询,重点是是可以混合和匹配来自基本表(或者其他视图)的数据,从而创建在很多方面像另一个基表那样起作用的对象.可以创建一个简单的查询,仅仅从一个表中选择几列,而忽略其他列:或者也 ...

  9. SQL Server 视图索引

    在视图上创建索引的另一个好处是:查询优化器开始在查询中使用视图索引,而不是直接在 FROM 子句中命令视图.这样一来,可从索引视图检索数据而无需重新编码,由此带来的高效率也使现有查询获益.在视图上创建 ...

随机推荐

  1. 英特尔® 实感™ SDK 架构

    英特尔® 实感™ SDK在架构上完全不同于其前代系统 — 英特尔® 感知计算 SDK. 如果您使用英特尔感知计算 SDK 进行应用开发,会很快发现,全新的 SDK 可提供增强型编程模式,从而可通过几种 ...

  2. 搭建Cocos2d-JS开发环境

    使用Cocos2d-JS引擎开发游戏,主要的程序代码是JavaScript语言,因此,凡是能够开发JavaScript语言工具都适用于Cocos2d-JS游戏开发.本书我们推荐WebStorm和Coc ...

  3. 异常getaddrinfo enotfound

    在看NodeJS开发指南这本书时,书中的一个例子,讲解http.request的.代码如下: var http = require('http'); var querystring = require ...

  4. Angular实现数据绑定,它实现原理是什么?

    简单的来说,就是给每个需要绑定的元素加上$watcher,缓存下oldValue,然后定时遍历所有的$watcher,比较newValue和oldValue,如果变化了就做更新的操作.

  5. 数组的join()函数操作

    join()函数的功能为:把数组的所有元素放入一个字符串,元素通过指定的分隔符分隔. 设置这样的数组操作 var a = []; a.push(1);a.push(3.1415926);a.push( ...

  6. JavaScript中Array的一些实用操作技巧

    最近在调试JSP页面时频繁与ajax打交道,在复杂场景下,ajax传参数就需要对大量参数进行处理.这时我才发现,熟练Array的处理真的会使开发轻松不少!! 关于Array Array的创建很灵活,可 ...

  7. tomcat中的get、post区别

    最近做一个项目,前台传到后台的数据是乱码.看着代码应该是正确的,但是就是有问题,然后请教了旁边的老司机才找到问题是什么.话不多说,下面是模拟情景的代码,其实也很简单,前台一个form表单,post   ...

  8. 济南学习 Day 3 T2 am

    看程序写结果(program)Time Limit:1000ms Memory Limit:64MB题目描述LYK 最近在准备 NOIP2017 的初赛,它最不擅长的就是看程序写结果了,因此它拼命地在 ...

  9. 1 。 LightOJ 1234 打表法(数据太大,把数据缩小100倍)

    原题链接http://acm.hust.edu.cn/vjudge/contest/121397#problem/A Description In mathematics, the nth harmo ...

  10. java 设计模式之单例模式

    -------Success is getting what you want, happiness is wanting what you get. java设计模式之单例模式(Singleton) ...