摘要:函数,表,存储过程,视图等的定义语句
sys.all_sql_modules 视图, 它里面存储了函数,表,存储过程,视图等的定义语句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
示例如下:取得某个函数的定义
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'