限制条件一:定义视图的查询语句中不能够使用某些关键字
我们都知道,视图其实就是一组查询语句组成。或者说,视图是封装查询语句的一个工具。在查询语句中,我们可以通过一些关键字来格式化显示的结果。如我们在平时工作中,经常会需要把某张表中的数据跟另外一张表进行合并。此时,数据库管理员就可以利用Select Into语句来完成。先把数据从某个表中查询出来,然后再添加到某个表中。
当经常需要类似的操作时,我们是否可以把它制作成一张视图。每次有需要的时候,只需要运行这个视图即可,而不用每次都进行重新书写SQL代码。不过可惜的是,结果是否定的。在SQL Server数据库的视图中,是不能够带有Into关键字。如果要实现类似的功能,只有通过函数或者过程来实现。
另外,跟Oracle数据库不同的是,在微软的SQL Server数据库中创建视图的时候,还有一个额外的限制。就是不能够在创建视图的查询语句中,使用order by排序语句。这是一个很特殊的规定。一些Oracle的数据库管理员,在使用SQL Server数据库创建视图的时候,经常会犯类似的错误。他们就搞不明白,为什么Oracle数据库中可行,但是在微软的数据库中则行不通呢?这恐怕只有微软数据库产品的设计者才能够回答的问题。总之我们要记住的就是,在SQL Server数据库中,建立视图时,查询语句中不能够包含Order By语句。
限制条件二:视图数据的更改
当用户更新视图中的数据时,其实更改的是其对应的数据表的数据。无论是对视图中的数据进行更改,还是在视图中插入或者删除数据,都是类似的道理。但是,不是所有视图都可以进行更改。如下面的这些视图,在SQL Server数据库中就不能够直接对其内容进行更新,否则,系统会拒绝这种非法的操作。
如在一个视图中,若采用Group By子句,对视图中的内容进行了汇总。则用户就不能够对这张视图进行更新。这主要是因为采用Group By子句对查询结果进行汇总在后,视图中就会丢失这条纪录的物理存储位置。如此,系统就无法找到需要更新的纪录。若用户想要在视图中更改数据,则数据库管理员就不能够在视图中添加这个Group BY分组语句。
如不能够使用Distinct关键字。这个关键字的用途就是去除重复的纪录。如没有添加这个关键字的时候,视图查询出来的纪录有250条。添加了这个关键字后,数据库就会剔除重复的纪录,只显示不重复的50条纪录。此时,若用户要改变其中一个数据,则数据库就不知道其到底需要更改哪条纪录。因为视图中看起来只有一条纪录,而在基础表中可能对有的纪录有几十条。为此,若在视图中采用了Distinct关键字的话,就无法对视图中的内容进行更改。
如果在视图中有AVG、MAX等函数,则也不能够对其进行更新。如在一张视图中,其采用了SUN函数来汇总员工的工资时,此时,就不能够对这张表进行更新。这是数据库为了保障数据一致性所添加的限制条件。
可见,试图虽然方便、安全,但是,其仍然不能够代替表的地位。当需要对一些表中的数据进行更新时,我们往往更多的通过对表的操作来完成。因为对视图内容进行直接更改的话,需要遵守一些限制条件。在实际工作中,更多的处理规则是通过前台程序直接更改后台基础表。至于这些表中数据的安全性,则要依靠前台应用程序来保护。确保更改的准确性、合法性。
限制条件三:要对某些列取别名,并保证列名的唯一
在表关联查询的时候,当不同表的列名相同时,只需要加上表的前缀即可。不需要对列另外进行命名。但是,在创建视图时就会出现问题,数据库会提示 “duplicate column name”的错误提示,警告用户有重复的列名。有时候,用户利用Select语句连接多个来自不同表的列,若拥有相同的名字,则这个语句仍然可以执行。但是,若把它复制到创建视图的窗口,创建视图时,就会不成功。
查询语句跟创建视图的查询语句还有很多类似的差异。如有时候,我们在查询语句中,可能会比较频繁的采用一些算术表达式;或者在查询语句中使用函数等等。在查询的时候,我们可以不给这个列“取名”。数据库在查询的时候,会自动给其命名。但是,在创建视图时,数据库系统就会给你出难题。系统会提醒你为列取别名。
从以上两个例子中,我们可以看出,虽然视图是对SQL语句的封装,但是,两者仍然有差异。创建视图的查询语句必须要遵守一定的限制。如要保证视图的各个列名的唯一;如果自阿视图中某一列是一个算术表达式、函数或者常数的时候,要给其取名字,等等。
限制条件四:权限上的双重限制
为了保障基础表数据的安全性,在视图创建的时候,其权限控制比较严格。
一方面,若用户需要创建视图,则必须要有数据库视图创建的权限。这是视图建立时必须遵循的一个基本条件。如有些数据库管理员虽然具有表的创建、修改权限;但是,这并不表示这个数据库管理员就有建立视图的权限。恰恰相反,在大型数据库设计中,往往会对数据库管理员进行分工。建立基础表的就只管建立基础表;负责创建视图的就只有创建视图的权限。
其次,在具有创建视图权限的同时,用户还必须具有访问对应表的权限。如某个数据库管理员,已经有了创建视图的权限。此时,若其需要创建一张员工工资信息的视图,还不一定会成功。这还要这个数据库管理员有美誉跟工资信息相关的基础表的访问权限。如建立员工工资信息这张视图一共涉及到五张表,则这个数据库管理员就需要拥有者每张表的查询权限。若没有的话,则建立这张视图就会以失败告终。
第三,就是视图权限的继承问题。如上面的例子中,这个数据库管理员不是基础表的所有者。但是经过所有者的授权,他就可以对这个基础表进行访问,就可以以此为基础建立视图。但是,这个数据库管理员有没有把对这个基础表的访问权限再授权给其他人呢?如他能否授权给A用户访问员工考勤信息表呢?答案是不一定。默认情况下,数据库管理员不能够再对其他用户进行授权。但是,若基础表的所有者,把这个权利给了数据库管理员之后,则他就可以对用户进行重新授权。让数据库管理员可以给A用户进行授权,让其可以进行相关的操作。
综合上面所述,视图虽然灵活,安全,方便,但是其仍然有比较多的限制条件。
根据经验,一般在报表、表单等等工作上,采用视图会更加的合理。因为其 SQL语句可以重复使用。而在基础表更新上,包括纪录的更改、删除或者插入上,往往是直接对基础表进行更新。对于一些表的约束,可以通过触发器、规则等等来实现;甚至可以通过前台SQL语句直接实现约束。
作为数据库管理员,要有这个能力,能够判断在什么时候使用视图,什么时候直接调用基础表。
分享到:
相关推荐
在SQL Server数据库管理系统中,视图是数据库设计和数据查询中的一个重要概念。视图可以被理解为一个虚拟的表,它并不实际存储数据,而是基于一个或多个表或视图的SELECT语句结果集。视图是数据库对象,提供了一种...
SQL Server视图是一种非常重要的数据库对象,它在数据库管理和数据查询中扮演着不可或缺的角色。视图实际上是基于一个或多个表的SELECT查询结果的虚拟表,它并不存储实际数据,而是存储查询语句本身。在使用时,视图...
SQL Server 2008 创建视图 - SQL 语句方式 本资源主要介绍了在 SQL Server ...本资源详细地介绍了在 SQL Server 2008 中使用 SQL 语句创建视图的方法和语法结构,并提供了多个实例来演示创建视图的过程和应用场景。
例如,在创建`stuview2`时,我们限制了只有性别为"男"的学生信息会被显示,如果尝试更新或插入不符合这个条件的数据,SQL Server将拒绝执行。 - 创建`stuview3`时,我们使用了`WITH ENCRYPTION`子句,这使得视图的...
4. **视图限制**:了解并遵守SQL Server对索引视图的限制条件。 #### 十七、GROUP BY限制 在索引视图中使用`GROUP BY`时需要注意一些限制条件,例如不能使用非确定性函数等。 #### 十八、有关索引的要求 创建...
在SQL Server数据库管理系统中,视图是数据库设计和开发中的一个重要组成...总之,SQL Server视图是数据库开发中不可或缺的工具,它提高了数据管理的灵活性、安全性和效率,使得复杂的查询和数据操作变得更加简单易行。
视图是 SQL Server 中的一个重要概念,它可以将多个表结合起来,提供一个统一的访问接口。基于视图的数据库安全模型可以提供更加安全的数据保护机制。该模型可以将权限控制在视图级别,对于不同的用户提供不同的访问...
SQL Server 2014是微软推出的一款关系型数据库管理系统,它在企业...通过这个安装包,你不仅能够搭建一个运行SQL Server 2014的环境,还能使用强大的管理工具进行数据库管理,从而开启在SQL Server上的学习和工作之旅。
SQL Server视图是数据库中的一种重要数据结构,它为数据库用户提供了一种从多个角度观察和访问数据的方式。视图本质上是一个虚拟表,它通过SQL查询语句定义,而这个查询语句确定了视图中将要显示的数据。尽管视图看...
SQL Server视图可以看作是一个虚拟表,它由一个或多个表的查询结果定义。视图可以包含多个表的数据,但由于其本质上是虚拟的,因此不存储数据本身。尽管视图看起来就像是普通的表一样,可以对其执行插入(Insert)、...
在SQL Server 2000中,数据库对象如存储过程、函数、视图和触发器等,有时会被加密以保护其源代码不被查看或修改。这种加密是通过使用SQL Server的内置加密机制来实现的,它使得普通用户无法直接读取到这些对象的...
SQL Server 2005 中的视图是一种虚拟表,它不实际存储数据,而是基于一个或多个基础表或视图的查询结果集。视图在数据库中扮演着重要的角色,提供了一种方式来抽象和简化复杂的数据库结构,使得用户能够更轻松地访问...
在SQL Server数据库管理系统中,存储过程、函数和视图是三个重要的数据库对象,它们在数据库设计和数据操作中起着核心作用。以下是对这些概念的详细说明: **存储过程(Stored Procedure)** 存储过程是一组预编译...
在SQL Server 2008中,创建视图是一项重要的数据库管理任务,它允许用户根据需求定制数据查询的结果,提供了一种虚拟表的形式,显示来自一个或多个表的数据。视图并不存储数据本身,而是基于已有表的查询结果。下面...
这时,可以使用如`mss2sql.rar`这样的工具,它通常能帮助用户自动化地将MySQL的表结构、数据、视图、存储过程等对象转换为SQL Server兼容的脚本,从而实现迁移。 转换过程一般包括以下步骤: 1. 数据库对象分析:...
### SQLServer SQL语法大全 #### 创建数据库 在SQL Server中创建数据库是一项基本操作,通过`CREATE DATABASE`命令来实现。创建数据库时可以指定文件和日志文件的位置、初始大小及增长方式等参数。 **语法示例:**...
在这个"绿色版SQL Server客户端工具"中,我们主要关注的是一个轻量级、便携式的查询分析器,它无需安装即可在客户的计算机上运行,为数据库操作提供了便利。 首先,"查询分析器"是SQL Server的重要组成部分,它是...
在 Windows Server 2008 64 位操作系统中使用 SQL Server 建立 Linked Server 连接 Oracle 需要下载并安装 Oracle 客户端软件,创建 Linked Server,添加远程登录信息,并创建 View,以便在 SQL Server 中访问 ...
3. **数据库架构**:SQL Server 2000中的数据库由表、视图、存储过程、触发器、索引、约束等构成。表是数据的主要载体,视图是虚拟的表,存储过程是预编译的SQL语句集合,触发器用于响应特定的数据更改事件,索引...
总结来说,优化SQL Server的内存配置是一个涉及多个方面的问题,包括理解操作系统和SQL Server版本的内存限制、正确设置内存参数、监控内存使用情况以及根据系统负载和需求进行动态调整。只有深入了解这些知识点,...