4

我正在使用以下语句在 SQL Server 2008R2/2012 上创建用户定义的表类型:

CREATE TYPE [MySchemaName].[MyUserTableType] 
   As Table ( [Id] varchar(20) NOT NULL );

这按预期工作。

我还有一个存储过程,它删除给定模式的所有关联对象。这是我的用户定义表类型无法正常工作的地方。我期望这些类型是使用关联的架构创建的。

如果我尝试删除架构,它会抱怨架构与我的用户定义的表类型相关联。因此它不会被删除。

但是,如果我查询我的数据库中的所有 TYPE_TABLE 对象,它会告诉我我的表类型不属于我的模式。它们属于模式“sys”

SELECT name, schema_id, type_desc 
FROM [TESTDB].SYS.OBJECTS 
WHERE type_desc = 'TYPE_TABLE';

SELECT * FROM sys.schemas;

知道为什么吗?

这是我输出的截图 在此处输入图像描述

4

1 回答 1

6

而不是寻找sys.objects这些,你应该寻找sys.typesor sys.table_types(这也暴露了type_table_object_id)。

SELECT name,
       schema_id /*Will be the "test" schema id*/
FROM   sys.types
WHERE  is_table_type = 1
       AND name = 'MyUserTableType'

当您创建用户定义的类型时,它会向sys.sysscalartypes用户提供的架构和名称添加一行,并在架构中sys.sysschobjs使用系统生成的名称添加一行sys。系统生成的名称是通过连接TT_+ FriendlyName + _+ Hex 版本的对象 id 创建的。

这两个实体通过以下方式关联在一起sys.syssingleobjrefs

/*This query only works via the DAC*/
SELECT so.id AS object_id,
       st.id AS user_type_id,
       *
FROM   sys.sysschobjs so
       JOIN sys.syssingleobjrefs sor
         ON sor.indepid = so.id
       JOIN sys.sysscalartypes st
         ON st.id = sor.depid
WHERE  st.name = 'MyUserTableType' 
于 2013-12-10T00:45:49.423 回答