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

    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

  • 相关阅读:
    [LeetCode] Maximum Depth of Binary Tree
    C++11中常用的几个简写
    [LeetCode] Word Break
    [LeetCode] Linked List Cycle II
    sizeof
    string和整形数据之间的转换
    ASCII
    [LeetCode] Linked List Cycle
    机器学习总结-线性回归
    推荐系统初探
  • 原文地址:https://www.cnblogs.com/wx881208/p/5051059.html
Copyright © 2011-2022 走看看