SQL Server 2000中,当新建一个空的数据库后,在查询分析器中执行
sp_database 或select * from sysobjects where xtype = 'U'
都会得到dtproperties表,并显示为用户表, 可这个表我从没有创建过。但是在企业管理器中,dtproperties却显示为系统表。难道是bug ? 查看dtproperties,里面没有数据,是个空表。在SQL Server联机丛书里没有关于这个表的描述。
dtproperties表在企业管理器中无法删除,但在查询分析器中 执行drop table dtproperties却可以删除。
手工建立一个表,表名就叫dtproperties,然后再查看,在企业管理器中赫然显示为系统表!! 看来Bug是一定的了。
重新创建一个数据库, 写个触发器,让其在dtproperties表执行insert时执行,然后在SQL Server里随意操作,hehe,终于发现,在新建关系图时,dtproperties表被插入数据,看来它是用来存储数据关系图的。呵呵,想点办法,数据关系图以后也可以备份下来了。
再用drop table dtproperties删除表dtproperties,[手工创建dtproperties ,结构任意,] 然后在企业管理器中新建数据关系图,呵呵,SQL Server报错!再次证实前面的猜想!
SQL Server 2005中dtproperties 表不存在了,取而代之的是sysdiagram (记不住具体的名称了) ,这个bug也不存在了,SQL Server 2005中的系统表和SQL Server 2000有了很大的不同。
这个很郁闷,我的SQL 仍用的是2000版,..... ,我的Visual Studio NET环境也没调.
--------------------------------------------
在数据库上运行下列脚本将使 SQL Server 企业管理器可以处理该数据库中的数据库关系图:
alter table dbo.dtproperties add uvalue nvarchar(255) null
go
if exists(select * from dbo.dtproperties)
exec(’update dbo.dtproperties set uvalue = convert(nvarchar(255), value)’)
go
该脚本运行后,SQL Sever 2000 中的 SQL Sever 企业管理器和可视化数据库工具的早期版本都可以访问该数据库中的数据库关系图
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/35489/viewspace-607952/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/35489/viewspace-607952/