galbanum

学习是有始无终的事情

SQLServer视图(五)

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视图(四)
下一篇SQLServer视图(六)
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

关闭
关闭