今天向大家介绍Sql server 中的 sys.all_sql_modules 视图, 它里面存储了函数,表,存储过程,视图等的定义语句。
介绍这个视图之前先介绍下 sys.all_objects 视图,这个视图视图里有所有对象的名字(函数名,表名,存储过程名,视图名,(主/外)键名,索引名)。
在这个视图(sys.all_objects)里我们关心的列有:
· Name 存储 函数名,表名,存储过程名,视图名,(主/外)键名,索引名
· object_id 对象的唯一标识,与sys.all_sql_modules 的连接条件
· Type 对象的类型
缩写 描述
FN SQL_SCALAR_FUNCTION
IF SQL_INLINE_TABLE_VALUED_FUNCTION
F FOREIGN_KEY_CONSTRAINT
U USER_TABLE
SQ SERVICE_QUEUE
D DEFAULT_CONSTRAINT
S SYSTEM_TABLE
P SQL_STORED_PROCEDURE
PK PRIMARY_KEY_CONSTRAINT
V VIEW
IT INTERNAL_TABLE
X EXTENDED_STORED_PROCEDURE
TR SQL_TRIGGER
PC CLR_STORED_PROCEDURE
TF SQL_TABLE_VALUED_FUNCTION
回到sys.all_sql_modules 如果我想取得某个函数的定义该怎么写呢:
select definition fromsys.all_sql_modules sm
inner join sys.all_objects ao onsm.object_id = ao.object_id
where name ='functionName'and type ='FN'
如果想去表的定义语句,视图的定义语句就不需要我写出来了吧。
以上语句在Sql 2005和2008中测试过。