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中可以看出,无论是修改哪个数据表或删除数据表都会出现错误信息,不允许修改或删除。再仔细看一下创建视图的代码,有几个必须要注意的地方:
l 只有使用WITH SCHEMABINDING之后,才能限制被引用的数据表或视图不被修改或删除。
l 使用了WITH SCHEMABINDING参数后,在select语句里,不能使用select *来代表所有字段,必须指定字段名。
l 使用了WITH SCHEMABINDING参数后,在select语句里所用到的数据表或视图名,必须要用owner.object方式来表示。