博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
SQLServer之修改视图
阅读量:4971 次
发布时间:2019-06-12

本文共 2033 字,大约阅读时间需要 6 分钟。

修改视图注意事项

修改先前创建的视图。 其中包括索引视图。 ALTER VIEW不影响相关的存储过程或触发器,并且不会更改权限。

如果原来的视图定义是使用 WITH ENCRYPTION 或 CHECK OPTION创建的,则只有在 ALTER VIEW 中也包含这些选项时,才会启用这些选项。

如果当前所用的视图使用 ALTER VIEW 来修改,则数据库引擎使用对该视图的排他架构锁。 在授予锁时,如果该视图没有活动用户,则数据库引擎将从过程缓存中删除该视图的所有副本。 引用该视图的现有计划将继续保留在缓存中,但一旦被调用就会重新编译。

ALTER VIEW可应用于索引视图,但是,ALTER VIEW会无条件地删除视图的所有索引。

若要执行 ALTER VIEW,至少需要具有对 OBJECT 的 ALTER 权限。

使用SSMS数据库管理工具修改视图

1、连接数据库,选择数据库,展开数据库-》展开视图-》选择要修改的视图-》选择设计。

2、在关系图窗格中-》修改视图-》修改完成,点击保存。

3、使用修改的视图。

使用T-SQL脚本修改视图

语法:

--声明数据库引用

use 数据库名;
go

--修改视图

alter view [架构名][.]视图名
with encryption,schemabinding,view_metadata
as
select_statement
[check option];
go

语法解析:

schema_name

视图所属架构的名称。

view_name

要更改的视图。

column

将成为指定视图的一部分的一个或多个列的名称(以逗号分隔)。

encryption

适用范围: SQL Server 2008 到 SQL Server 2017 和 Azure SQL Database。

加密 sys.syscomments 中包含 ALTER VIEW 语句文本的项。 WITH ENCRYPTION 可防止视图作为 SQL Server 复制的一部分进行发布。

schemabinding

将视图绑定到基础表的架构。 如果指定了 SCHEMABINDING,则不能以可影响视图定义的方式来修改基表。 必须首先修改或删除视图定义本身,然后才能删除要修改的表的相关性。 使用 SCHEMABINDING 时,select_statement 必须包含所引用的表、视图或用户定义函数的两部分名称 (schema.object)。 所有被引用对象都必须在同一个数据库内。

不能删除参与使用 SCHEMABINDING 子句创建的视图的表或视图,除非该视图已被删除或更改,而不再具有架构绑定。 否则, 数据库引擎将引发错误。 另外,如果对参与具有架构绑定的视图的表执行 ALTER TABLE 语句,而这些语句又会影响视图定义,则这些语句将会失败。

view_metadata

指定为引用视图的查询请求浏览模式的元数据时, SQL Server 实例将向 DB-Library、ODBC 和 OLE DB API 返回有关视图的元数据信息,而不返回基表的元数据信息。 浏览模式的元数据是 数据库引擎实例返回到客户端 DB-Library、ODBC 和 OLE DB API 的额外元数据。 如果使用此元数据,客户端 API 将可以实现可更新客户端游标。 浏览模式的元数据包含结果集中的列所属的基表的相关信息。

对于使用 VIEW_METADATA 创建的视图,浏览模式的元数据在描述结果集内视图中的列时,将返回视图名,而不返回基表名。

使用 WITH VIEW_METADATA 创建视图时,如果该视图具有 INSERT 或 UPDATE INSTEAD OF 触发器,则视图的所有列(timestamp 列除外)都可更新。 有关详细信息,请参阅 CREATE VIEW (Transact-SQL) 中的“注释”部分。

as

视图要执行的操作。

select_statement

定义视图的 SELECT 语句。

with check option

要求对该视图执行的所有数据修改语句都必须符合 select_statement 中所设置的条件。

示例:

--声明数据库引用

use testss;
go

--修改视图

alter view dbo.view1
with encryption,schemabinding,view_metadata
as
select a.id,a.name,a.sex,a.height,b.id as classid
from dbo.test1 as a
inner join dbo.test3 as b on a.classid=b.id;
go

使用修改后的视图

 

转载于:https://www.cnblogs.com/vuenote/p/9869227.html

你可能感兴趣的文章
编写高质量代码--改善python程序的建议(六)
查看>>
windows xp 中的administrator帐户不在用户登录内怎么解决?
查看>>
接口和抽象类有什么区别
查看>>
Codeforces Round #206 (Div. 2)
查看>>
Mycat分表分库
查看>>
模板的文件名和方法名一定要一致!!
查看>>
**p
查看>>
优先队列详解
查看>>
VS2012 创建项目失败,,提示为找到约束。。。。
查看>>
设计类图
查看>>
类对象
查看>>
ios 上架流程
查看>>
ajax连接池和XMLHttpRequest
查看>>
[Voice communications] 声音的滤波
查看>>
BZOJ.3139.[HNOI2013]比赛(搜索 Hash)
查看>>
json在线解析
查看>>
存储设备形成的层次结构
查看>>
源码阅读 - java.util.concurrent (三)ConcurrentHashMap
查看>>
Daily Scrum 10.30
查看>>
SQL语言之概述(一)
查看>>