zoukankan      html  css  js  c++  java
  • SQL语句获取数据库中的表主键,自增列,所有列

     
    获取表主键
    1:SELECT TABLE_NAME,COLUMN_NAME FROM INFORMATION_SCHEMA.KEY_COLUMN_USAGEWHERE TABLE_NAME<>'dtproperties'
    2:EXEC sp_pkeys @table_name='表名'
    3:
    select o.name as 表名,c.name as 字段名,k.colid as 字段序号,k.keyno as 索引顺序,t.name as 类型
    from sysindexes i
    join sysindexkeys k on i.id = k.id and i.indid = k.indid
    join sysobjects o on i.id = o.id
    join syscolumns c on i.id=c.id and k.colid = c.colid
    join systypes t on c.xusertype=t.xusertype
    where o.xtype = 'U' and o.name='要查询的表名'
    and exists(select 1 from sysobjects where xtype = 'PK' and parent_obj=i.id and name = i.name)
    order by o.name,k.colid
     
     
    获取所有
    SELECT
    表名=case when a.colorder=1 then d.name else '' end,
    字段名=a.name,
    标识=case when COLUMNPROPERTY(a.id,a.name,'IsIdentity')=1 then '√' else '' end,
    主键=case when exists(SELECT 1 FROM sysobjects where xtype= 'PK' and name in (
    SELECT name FROM sysindexes WHERE indid in(
    SELECT indid FROM sysindexkeys WHERE id = a.id AND colid=a.colid
    ))) then '√' else '' end,
    类型=b.name,
    占用字节数=a.length,
    长度=COLUMNPROPERTY(a.id,a.name, 'PRECISION'),
    小数位数=isnull(COLUMNPROPERTY(a.id,a.name, 'Scale'),0),
    允许空=case when a.isnullable=1 then '√'else '' end,
    默认值=isnull(e.text, ''),
    字段说明=isnull(g.[value], '')
    FROM syscolumns a
    left join systypes b on a.xtype=b.xusertype
    inner join sysobjects d on a.id=d.id and d.xtype= 'U' and d.name <> 'dtproperties' and d.name = '要查询的表名'
    left join syscomments e on a.cdefault=e.id
    left join sys.extended_properties g on a.id=g.major_id and a.colid=g.minor_id and g.name='MS_Description'
    order by a.id,a.colorder
     
     
    获取表自增列名称 
    SELECT COLUMN_NAME as 标识 FROM INFORMATION_SCHEMA.columns
    WHERE TABLE_NAME='表名' AND COLUMNPROPERTY(OBJECT_ID('表名'),COLUMN_NAME,'IsIdentity')=1
    SELECT 标识 = case when COLUMNPROPERTY( a.id,a.name,'IsIdentity')=1 then a.name else 'NULL' end
    FROM syscolumns a
    inner join sysobjects d on a.id=d.id and d.xtype='U' and d.name<>'dtproperties'
    where d.name='TestType' order by a.id,a.colorder
     
    获取字段默认值
    select b.text as 字段默认值
    from syscolumns a left join syscomments b on a.cdefault = b.id
    where a.id = object_id('表名') and a.name = '字段名称'

    移植表: SELECT * INTO 库2.dbo.表2 FROM 库1.dbo.表1

    原文地址:https://www.cnblogs.com/mikun/archive/2011/06/12/2078979.html

  • 相关阅读:
    六种简单易理解的排序算法
    leetcode-數組篇
    leetcode-字符串篇
    java8 Optional优雅非空判断
    md2all 简单实用
    zooleeper面试题
    深入理解 JVM锁 与 分布式锁
    redission 高性能分布式锁
    Java传统 定时任务
    关于Zookeeper
  • 原文地址:https://www.cnblogs.com/caiyt/p/13055549.html
Copyright © 2011-2022 走看看