SQLServer视图(五)

转载 2007年09月17日 17:33:00

5.限制视图所用的表或视图不能更改设计和删除

由于视图和数据表是数据库中独立的两种对象,虽然视图要引用数据表,但是当引用的数据表删除或修改时,视图本身并不会被删除或修改,因此往往在删除数据表之后,会引起视图运行错误。如果在创建视图时使用了with schemabinding参数,就可以防止引用的数据表或视图删除或修改。

例七、创建两个数据表,再创建一个带with schemabinding参数的引用这两个数据表的视图,再试图修改和删除数据表。其代码如下:

--创建两个数据表

CREATE TABLE 例七_1(

         id int IDENTITY(1,1) NOT NULL PRIMARY KEY,

         username nchar(10) NULL

)

CREATE TABLE 例七_2(

         id int IDENTITY(1,1) NOT NULL PRIMARY KEY,

         newname nchar(10) NULL

)

GO

--创建视图

CREATE VIEW view_例七

         WITH SCHEMABINDING

         AS

         SELECT 例七_1.username,例七_2.newname

                   FROM dbo.例七_1 JOIN dbo.例七_2

                            ON 例七_1.id = 例七_2.id

GO

--修改数据表

PRINT ''

ALTER TABLE 例七_1

         ALTER COLUMN username nvarchar(100)

GO

PRINT ''

ALTER TABLE 例七_2

         ALTER COLUMN newname nvarchar(100)

GO

--删除数据表

PRINT ''

DROP TABLE 例七_1

GO

PRINT ''

DROP TABLE 例七_2

GO

其运行结果如9-11所示:

11限制视图所用的表不能更改设计和删除

在图9.11中可以看出,无论是修改哪个数据表或删除数据表都会出现错误信息,不允许修改或删除。再仔细看一下创建视图的代码,有几个必须要注意的地方:

只有使用WITH SCHEMABINDING之后,才能限制被引用的数据表或视图不被修改或删除。

使用了WITH SCHEMABINDING参数后,在select语句里,不能使用select *来代表所有字段,必须指定字段名。

使用了WITH SCHEMABINDING参数后,在select语句里所用到的数据表或视图名,必须要用owner.object方式来表示。

 

相关文章推荐

SQLserver的事务,索引,视图,函数,存储过程

一.事务      在sqlserver中当出现多条语句时,当其中有一条不合理,不会停止下来,      因此,我们会用事务去解决这个问题,当有一个错误时,不允许往下继续进行,     只有...

查询SQLServer2005中某个数据库中的表结构、索引、视图、存储过程、触发器以及自定义函数

(1)查询SQLServer2005中某个数据库中的表结构 SELECT 表名      = CASE WHEN A.COLORDER=1 THEN D.NAME ELSE '' E...

sqlserver视图

  • 2011年11月15日 19:02
  • 84KB
  • 下载

SQLServer之视图篇

视图是从一个或者几个基本表(或视图)导出的表。它与基本表不同,是一个虚表。数据库中只存放视图的定义,而不存在视图对应的数据,这些数据仍然存放在原来的基本表中。所以一旦基本表中的数据发生变化,从视图中查...

SqlServer第七章_实现视图

  • 2011年06月07日 08:49
  • 619KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:SQLServer视图(五)
举报原因:
原因补充:

(最多只允许输入30个字)