• 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

  • 相关阅读:
    c++ ShellExecuteEx调用java打包的exe程序
    麻省理工学院公开课-第四讲:快速排序 及 随机化 算法
    Win10的IIS与以前版本的一个区别
    干就行了!!!写程序就像珊瑚,分支太多,哪有那么多复用!
    NPoco的使用方法
    为什么前端要写标准代码?
    对于委托、事件、观察者模式最一目了然的代码段
    delphi处理消息的几种方式
    哎呀妈呀,吓死我了,幸好服务器没崩溃。
    Delphi的Hint介绍以及用其重写气泡提示以达到好看的效果
  • 原文地址:https://www.cnblogs.com/heys/p/1458040.html
Copyright © 2020-2023  润新知