sqlserver2005系统表、视图研究2

1、sys.all_objects(系统视图)数据库中所有的对象,包含了创建时间和最近修改时间。


--查找存储过程
--所有的存储过程
select * from sys.all_objects where type='P' order by modify_date desc
--2009年3月5号后新建的存储过程
select * from sys.all_objects where type='P' and create_date>'2009-3-5' order by name
--3月5号前建的3月5号后修改过的
select * from sys.all_objects where type='P' and modify_date>'2009-3-5' and create_date<'2009-3-5' order by name

2、sys.objects、sysobjects、syscolumns、systypes....

不想写了保存一个SQL吧。查找数据库信息的sql查出所有用户表的所有字段。


select
obj.name as tableName
 ,obj.type as objType
 ,ISNULL(tableRemark.value,N'') as tableRemark
 ,c.name as FieldName
 ,isnull(PFD.[value],'') as FieldRemark
 ,t.name as DateType
 ,c.prec as FieldLength
-- ,p.value as 字段说明
 ,ISNULL(m.text,N'') as DefaultValue
 ,C.isnullable
 ,ISNULL(IDX.PrimaryKey,0) as PrimaryKey
--标识的详细
--http://www.cnblogs.com/hzq3554055/archive/2008/03/08/1096820.html
 ,case when COLUMNPROPERTY(c.id,c.name,'IsIdentity')=1 then 1 else 0 end
 as IsIdentity
 ,IndexName=ISNULL(IDX.IndexName,N'')
 ,IndexSort=ISNULL(IDX.Sort,N'')
--DESC or ASC
 from sysobjects obj
 inner join syscolumns c
 on c.id=obj.id and obj.type='U'
 inner join systypes t
 on c.xusertype=t.xusertype
 left outer join syscomments m
 on c.cdefault=m.id
--表说明(默认MS_Description)
 left outer join sys.extended_properties tableRemark
 on tableRemark.class=1 and obj.id=tableRemark.major_id
 and tableRemark.minor_id=0 and tableRemark.name='MS_Description'
--取字段说明(默认MS_Description)
 LEFT outer JOIN sys.extended_properties PFD
 ON PFD.class=1
 AND c.[id]=PFD.major_id
 AND c.colid=PFD.minor_id
 and PFD.name='MS_Description'
 left outer join
 (
 select
 IDXC.[object_id],
 IDXC.column_id,
 Sort=CASE INDEXKEY_PROPERTY(IDXC.[object_id],IDXC.index_id,IDXC.index_column_id,'IsDescending')
 WHEN 1 THEN 'DESC' WHEN 0 THEN 'ASC' ELSE '' END,
 PrimaryKey=CASE WHEN IDX.is_primary_key=1 THEN 1 ELSE 0 END,
 IndexName=IDX.Name
 from sys.indexes IDX
 INNER JOIN sys.index_columns IDXC
 ON IDX.[object_id]=IDXC.[object_id] AND IDX.index_id=IDXC.index_id
 LEFT outer JOIN sys.key_constraints KC
 ON IDX.[object_id]=KC.[parent_object_id] AND IDX.index_id=KC.unique_index_id
 INNER JOIN -- 对于一个列包含多个索引的情况,只显示第1个索引信息
 (
 SELECT [object_id], Column_id, index_id=MIN(index_id)
 FROM sys.index_columns
 GROUP BY [object_id], Column_id
 ) IDXCUQ
 ON IDXC.[object_id]=IDXCUQ.[object_id]
 AND IDXC.Column_id=IDXCUQ.Column_id
 AND IDXC.index_id=IDXCUQ.index_id
 ) IDX
 ON C.[id]=IDX.[object_id]
 AND C.colid=IDX.column_id
 order by obj.name

 

 

posted @ 2009-05-15 23:21  BB_Coder  阅读(393)  评论(0编辑  收藏  举报