zoukankan      html  css  js  c++  java
  • 读取SQLServer 数据表结构

    刚好需要这个过程, 在网上找了几个, 感觉都差一些, 其SQL都特别长. 而且我特别需要用到聚类索引, 自己写了个, 这是程序开发使用到的版本.

    select o.name tablename, c.name fieldname, t.name fieldtype, columnproperty(c.id,c.name,'PRECISION') fieldlen, c.Scale,c.length,
      c.colid fieldorder, c.isnullable, 
      
    case when c.colid in(select ik.colid
        
    from sysindexes i, Sysindexkeys ik, sysobjects oo
        
    where i.id=ik.id and i.indid=ik.indid
          
    and i.name=oo.name and oo.xtype='PK' --主键
          and o.id=i.id 
      ) 
    then 1 else 0 end isPrimaryKey,
      
    case when c.colid in(select ik.colid
        
    from sysindexes i, Sysindexkeys ik
        
    where i.id=ik.id and i.indid=ik.indid
          
    and o.id=i.id and i.indid=1 --聚类索引
      ) then 1 else 0 end isClusterKey,
      
    columnproperty( c.id, c.name,'IsIdentity') IsIdentity,
      
    isnull(m.text,'') defaultvalue
    from sysobjects o, syscolumns c, systypes t, syscomments m
    where o.xtype='U'
      
    and o.id=c.id 
      
    and c.xtype=t.xtype
      
    and c.cdefault*=m.id
    order by o.name, c.colid

    程序使用到的版本是否用0/1表示, 如果用在文档整理, 难看得要命, 优化了个文档版本的,在查询分析器找出来还是蛮好看的.

    select case when c.colid=1 then o.name else '' end 表名, 
      c.colid 顺序, 
      c.name 字段名, 
      t.name 字段类型, 
      
    columnproperty(c.id,c.name,'PRECISION') 字段长度, 
      
    isnull(c.Scale,'') 小数位,
      c.length 占用字节,
      
    case when c.isnullable=1 then '' else '' end 可为空, 
      
    case when c.colid in(select ik.colid
        
    from sysindexes i, Sysindexkeys ik, sysobjects oo
        
    where i.id=ik.id and i.indid=ik.indid
          
    and i.name=oo.name and oo.xtype='PK' --主键
          and o.id=i.id 
      ) 
    then '' else '' end 主键,
      
    case when c.colid in(select ik.colid
        
    from sysindexes i, Sysindexkeys ik
        
    where i.id=ik.id and i.indid=ik.indid
          
    and o.id=i.id and i.indid=1 --聚类索引
      ) then '' else '' end 聚类索引,
      
    case when columnproperty( c.id, c.name,'IsIdentity')=1 then '' else '' end 自增长,
      
    isnull(m.text,'') 默认值
    from sysobjects o, syscolumns c, systypes t, syscomments m
    where o.xtype='U'
      
    and o.id=c.id 
      
    and c.xtype=t.xtype
      
    and c.cdefault*=m.id
    order by o.name, c.colid

     

  • 相关阅读:
    (cocos2d-js游戏)測试你的反应速度----------基本逻辑(上)
    Ubuntu上安装flashplayer
    多线程中的"断点"续传《notify()和wait()》
    HTML高级标签之表格标签
    leetcode
    4星|《经济学通识课》:深入浅出的经济学思想发展简史
    1星|《追随》:洞察力太差,有效信息太少,咨询经验太少(举的例子以跟自己孩子的互动为主)
    3星|《在苍茫中传灯》:国外投资业经典图书的内容介绍与学习心得
    2星|《新物种爆炸》:用自造的新名词把已知事情换了个说法。语文与逻辑都比较差。
    老钱观美业
  • 原文地址:https://www.cnblogs.com/jacker1979/p/553387.html
Copyright © 2011-2022 走看看