แบบสอบถามเซิร์ฟเวอร์ SQL เพื่อรับรายการคอลัมน์ในตารางพร้อมกับชนิดข้อมูล, ข้อ จำกัด ไม่ใช่ NULL และคีย์หลัก


229

ฉันต้องเขียนแบบสอบถามบนเซิร์ฟเวอร์ SQL เพื่อรับรายการคอลัมน์ในตารางเฉพาะประเภทข้อมูลที่เชื่อมโยง (มีความยาว) และหากไม่เป็นโมฆะ และฉันได้ทำสิ่งนี้มาก

แต่ตอนนี้ฉันต้องได้รับในตารางเดียวกันกับคอลัมน์ - TRUEถ้าคอลัมน์นั้นเป็นคีย์หลัก

ฉันจะทำสิ่งนี้ได้อย่างไร

ผลลัพธ์ที่คาดหวังของฉันคือ:

Column name | Data type | Length | isnull | Pk

2
คุณสามารถแสดงรหัสที่คุณมีอยู่แล้วได้หรือไม่?
DOK

คำตอบ:


478

หากต้องการหลีกเลี่ยงแถวที่ซ้ำกันสำหรับบางคอลัมน์ให้ใช้ user_type_id แทน system_type_id

SELECT 
    c.name 'Column Name',
    t.Name 'Data type',
    c.max_length 'Max Length',
    c.precision ,
    c.scale ,
    c.is_nullable,
    ISNULL(i.is_primary_key, 0) 'Primary Key'
FROM    
    sys.columns c
INNER JOIN 
    sys.types t ON c.user_type_id = t.user_type_id
LEFT OUTER JOIN 
    sys.index_columns ic ON ic.object_id = c.object_id AND ic.column_id = c.column_id
LEFT OUTER JOIN 
    sys.indexes i ON ic.object_id = i.object_id AND ic.index_id = i.index_id
WHERE
    c.object_id = OBJECT_ID('YourTableName')

เพียงแทนที่YourTableNameด้วยชื่อตารางจริงของคุณใช้งานได้กับ SQL Server 2005 ขึ้นไป

ในกรณีที่คุณใช้สกีมาให้แทนที่YourTableName โดยYourSchemaName.YourTableNameที่YourSchemaNameชื่อสกีมาที่แท้จริงและYourTableNameเป็นชื่อตารางจริง


2
สิ่งนี้ให้ความยาวที่ไม่ถูกต้องสำหรับคอลัมน์ประเภท nvarchar มันให้ความยาวไบต์ที่สองเท่าความยาวในประเภทคอลัมน์
Andrew Savinykh

14
ความยาวเหล่านั้นไม่ถูกต้อง - มันให้ความยาวไบต์ - นั่นคือความยาวสูงสุดที่เป็นไปได้ในหน่วยไบต์ ... หากคุณต้องการคำนวณพื้นที่ ฯลฯ นั่นคือความยาวที่คุณต้องการรับ ....
marc_s

2
ใช้งานได้ดีสำหรับฉัน SQL Server 2012 :)
Doc Holiday

2
WHERE c.object_id = OBJECT_ID ('YourTableName') .... ฉันต้องการ WHERE c.object_id = OBJECT_ID ('MySchema.MyTableName') จากนั้นทุกอย่างทำงานได้ดี
Ivan

7
แบบสอบถามนี้จะส่งคืนคอลัมน์ที่ซ้ำซ้อนหากคุณมีดัชนีหลายรายการที่เกี่ยวข้องกับคอลัมน์เดียวกัน หากต้องการแก้ไขให้แทนที่การรวมสองครั้งล่าสุดด้วย: LEFT OUTER JOIN sys.index_columns ic LEFT OUTER JOIN sys.indexes i ON ic.object_id = i.object_id AND ic.index_id = i.index_id ON ic.object_id = c.object_id AND ic.column_id = c.column_id AND i.is_primary_key=1
Razvan Socol


72

คุณสามารถใช้แบบสอบถาม:

select COLUMN_NAME, DATA_TYPE, CHARACTER_MAXIMUM_LENGTH, 
       NUMERIC_PRECISION, DATETIME_PRECISION, 
       IS_NULLABLE 
from INFORMATION_SCHEMA.COLUMNS
where TABLE_NAME='TableName'

เพื่อรับข้อมูลเมตาทั้งหมดที่คุณต้องการยกเว้นข้อมูล Pk


2
ฉันทำอย่างนั้น :) แต่ฉันต้องการ PK ด้วย: |
Shrayas


1
นี่มันยอดเยี่ยมเพราะมันใช้ได้กับเวอร์ชั่น SS ที่เก่ากว่า 2005 ขอบคุณ!
Karl Hoaglund

19

ใน SQL 2012 คุณสามารถใช้:

EXEC sp_describe_first_result_set N'SELECT * FROM [TableName]'

สิ่งนี้จะให้ชื่อคอลัมน์พร้อมกับคุณสมบัติของพวกเขา


13

ลองสิ่งนี้:

select COLUMN_NAME, DATA_TYPE, CHARACTER_MAXIMUM_LENGTH, IS_NULLABLE 
from INFORMATION_SCHEMA.COLUMNS IC
where TABLE_NAME = 'tablename' and COLUMN_NAME = 'columnname'

2
คำตอบของคุณแตกต่างจากที่โพสต์โดย Ajadex อย่างไร คำตอบทั้งสองจะไม่ส่งคืนข้อมูลคีย์หลัก
Artemix

10

เพื่อให้แน่ใจว่าคุณได้รับความยาวที่เหมาะสมคุณจะต้องพิจารณาชนิด Unicode เป็นกรณีพิเศษ ดูรหัสด้านล่าง

สำหรับข้อมูลเพิ่มเติมโปรดดูที่: https://msdn.microsoft.com/en-us/library/ms176106.aspx

SELECT 
   c.name 'Column Name',
   t.name,
   t.name +
   CASE WHEN t.name IN ('char', 'varchar','nchar','nvarchar') THEN '('+

             CASE WHEN c.max_length=-1 THEN 'MAX'

                  ELSE CONVERT(VARCHAR(4),

                               CASE WHEN t.name IN ('nchar','nvarchar')

                               THEN  c.max_length/2 ELSE c.max_length END )

                  END +')'

          WHEN t.name IN ('decimal','numeric')

                  THEN '('+ CONVERT(VARCHAR(4),c.precision)+','

                          + CONVERT(VARCHAR(4),c.Scale)+')'

                  ELSE '' END

   as "DDL name",
   c.max_length 'Max Length in Bytes',
   c.precision ,
   c.scale ,
   c.is_nullable,
   ISNULL(i.is_primary_key, 0) 'Primary Key'
FROM    
   sys.columns c
INNER JOIN 
   sys.types t ON c.user_type_id = t.user_type_id
LEFT OUTER JOIN 
   sys.index_columns ic ON ic.object_id = c.object_id AND ic.column_id = c.column_id
LEFT OUTER JOIN 
   sys.indexes i ON ic.object_id = i.object_id AND ic.index_id = i.index_id
WHERE
   c.object_id = OBJECT_ID('YourTableName')

1
ชื่อ DDL นั้นมีประโยชน์มากสำหรับ dynamic-sql ที่สร้างตาราง! ขอบคุณ !!
George Menoutis

6

ขยายคำตอบของ Alex คุณสามารถทำได้เพื่อรับข้อ จำกัด ของ PK

Select C.COLUMN_NAME, C.DATA_TYPE, C.CHARACTER_MAXIMUM_LENGTH, C.NUMERIC_PRECISION, C.IS_NULLABLE, TC.CONSTRAINT_NAME
From INFORMATION_SCHEMA.COLUMNS As C
    Left Join INFORMATION_SCHEMA.TABLE_CONSTRAINTS As TC
      On TC.TABLE_SCHEMA = C.TABLE_SCHEMA
          And TC.TABLE_NAME = C.TABLE_NAME
          And TC.CONSTRAINT_TYPE = 'PRIMARY KEY'
Where C.TABLE_NAME = 'Table'

ฉันต้องพลาดว่าคุณต้องการให้แฟล็กเพื่อตรวจสอบว่าคอลัมน์ที่กำหนดนั้นเป็นส่วนหนึ่งของ PK แทนที่จะเป็นชื่อของข้อ จำกัด PK หรือไม่ เพื่อที่คุณจะใช้:

Select C.COLUMN_NAME, C.DATA_TYPE, C.CHARACTER_MAXIMUM_LENGTH
    , C.NUMERIC_PRECISION, C.NUMERIC_SCALE
    , C.IS_NULLABLE
    , Case When Z.CONSTRAINT_NAME Is Null Then 0 Else 1 End As IsPartOfPrimaryKey
From INFORMATION_SCHEMA.COLUMNS As C
    Outer Apply (
                Select CCU.CONSTRAINT_NAME
                From INFORMATION_SCHEMA.TABLE_CONSTRAINTS As TC
                    Join INFORMATION_SCHEMA.CONSTRAINT_COLUMN_USAGE As CCU
                        On CCU.CONSTRAINT_NAME = TC.CONSTRAINT_NAME
                Where TC.TABLE_SCHEMA = C.TABLE_SCHEMA
                    And TC.TABLE_NAME = C.TABLE_NAME
                    And TC.CONSTRAINT_TYPE = 'PRIMARY KEY'
                    And CCU.COLUMN_NAME = C.COLUMN_NAME
                ) As Z
Where C.TABLE_NAME = 'Table'

ดี. มันไม่ได้ให้ผลลัพธ์ตามที่ต้องการ :(
Shrayas

5

ขาวชื่อตารางในตัวแก้ไขแบบสอบถามเลือกชื่อและกด Alt + F1 และมันจะนำข้อมูลทั้งหมดของตาราง


เขาถามคำถาม แต่คุณพูดถูกวิธีนี้จะช่วยให้คุณเห็นข้อมูลทั้งหมด
Rafa Barragan

แต่ยังคง; ประณีตมาก :-)
netfed

4
SELECT COLUMN_NAME, IS_NULLABLE, DATA_TYPE, CHARACTER_MAXIMUM_LENGTH FROM information_schema.columns WHERE table_name = '<name_of_table_or_view>'

เรียกใช้SELECT *ในข้อความข้างต้นเพื่อดูว่า data_schema.columns ส่งคืนอย่างไร

คำถามนี้ได้รับคำตอบก่อนหน้านี้ - https://stackoverflow.com/a/11268456/6169225


ถ้าคำถามนี้ได้รับการตอบธงโพสต์เป็นซ้ำ
Martijn Pieters


3
IF EXISTS (SELECT 1 FROM INFORMATION_SCHEMA.TABLES 
     WHERE TABLE_TYPE = 'BASE TABLE' AND TABLE_NAME = 'Table')
      BEGIN
        SELECT COLS.COLUMN_NAME, COLS.DATA_TYPE, COLS.CHARACTER_MAXIMUM_LENGTH, 
              (SELECT 'Yes' FROM INFORMATION_SCHEMA.TABLE_CONSTRAINTS TC JOIN INFORMATION_SCHEMA.KEY_COLUMN_USAGE KCU
                              ON COLS.TABLE_NAME = TC.TABLE_NAME 
                             AND TC.CONSTRAINT_TYPE = 'PRIMARY KEY'
                             AND KCU.TABLE_NAME = TC.TABLE_NAME
                             AND KCU.CONSTRAINT_NAME = TC.CONSTRAINT_NAME
                             AND KCU.COLUMN_NAME = COLS.COLUMN_NAME) AS KeyX
        FROM INFORMATION_SCHEMA.COLUMNS COLS WHERE TABLE_NAME = 'Table' ORDER BY KeyX DESC, COLUMN_NAME
      END

3

การใส่คำตอบลงไปในวงแหวนสิ่งนี้จะทำให้คุณมีคอลัมน์เหล่านั้นและอีกมากมาย:

SELECT col.TABLE_CATALOG AS [Database]
     , col.TABLE_SCHEMA AS Owner
     , col.TABLE_NAME AS TableName
     , col.COLUMN_NAME AS ColumnName
     , col.ORDINAL_POSITION AS OrdinalPosition
     , col.COLUMN_DEFAULT AS DefaultSetting
     , col.DATA_TYPE AS DataType
     , col.CHARACTER_MAXIMUM_LENGTH AS MaxLength
     , col.DATETIME_PRECISION AS DatePrecision
     , CAST(CASE col.IS_NULLABLE
                WHEN 'NO' THEN 0
                ELSE 1
            END AS bit)AS IsNullable
     , COLUMNPROPERTY(OBJECT_ID('[' + col.TABLE_SCHEMA + '].[' + col.TABLE_NAME + ']'), col.COLUMN_NAME, 'IsIdentity')AS IsIdentity
     , COLUMNPROPERTY(OBJECT_ID('[' + col.TABLE_SCHEMA + '].[' + col.TABLE_NAME + ']'), col.COLUMN_NAME, 'IsComputed')AS IsComputed
     , CAST(ISNULL(pk.is_primary_key, 0)AS bit)AS IsPrimaryKey
  FROM INFORMATION_SCHEMA.COLUMNS AS col
       LEFT JOIN(SELECT SCHEMA_NAME(o.schema_id)AS TABLE_SCHEMA
                      , o.name AS TABLE_NAME
                      , c.name AS COLUMN_NAME
                      , i.is_primary_key
                   FROM sys.indexes AS i JOIN sys.index_columns AS ic ON i.object_id = ic.object_id
                                                                     AND i.index_id = ic.index_id
                                         JOIN sys.objects AS o ON i.object_id = o.object_id
                                         LEFT JOIN sys.columns AS c ON ic.object_id = c.object_id
                                                                   AND c.column_id = ic.column_id
                  WHERE i.is_primary_key = 1)AS pk ON col.TABLE_NAME = pk.TABLE_NAME
                                                  AND col.TABLE_SCHEMA = pk.TABLE_SCHEMA
                                                  AND col.COLUMN_NAME = pk.COLUMN_NAME
 WHERE col.TABLE_NAME = 'YourTableName'
   AND col.TABLE_SCHEMA = 'dbo'
 ORDER BY col.TABLE_NAME, col.ORDINAL_POSITION;

2
select
      c.name as [column name], 
      t.name as [type name],
      tbl.name as [table name]
from sys.columns c
         inner join sys.types t 
      on c.system_type_id = t.system_type_id 
         inner join sys.tables tbl
      on c.object_id = tbl.object_id
where
      c.object_id = OBJECT_ID('YourTableName1') 
          and 
      t.name like '%YourSearchDataType%'
union
(select
      c.name as [column name], 
      t.name as [type name],
      tbl.name as [table name]
from sys.columns c
         inner join sys.types t 
      on c.system_type_id = t.system_type_id 
         inner join sys.tables tbl
      on c.object_id = tbl.object_id
where
      c.object_id = OBJECT_ID('YourTableName2') 
          and 
      t.name like '%YourSearchDataType%')
union
(select
      c.name as [column name], 
      t.name as [type name],
      tbl.name as [table name]
from sys.columns c
         inner join sys.types t 
      on c.system_type_id = t.system_type_id 
         inner join sys.tables tbl
      on c.object_id = tbl.object_id
where
      c.object_id = OBJECT_ID('YourTableName3') 
          and 
      t.name like '%YourSearchDataType%')
order by tbl.name

ในการค้นหาคอลัมน์ที่อยู่ในตารางโดยยึดตามชนิดข้อมูลการค้นหาของคุณสำหรับสามตารางที่แตกต่างกันในฐานข้อมูลเดียว แบบสอบถามนี้สามารถขยายได้ถึงตาราง 'n'


2

ค้นหาผลลัพธ์การรวมสำหรับประเภทข้อมูลและความยาวและเป็นโมฆะในรูปแบบของ "NULL" และ "ไม่เป็นโมฆะ" ใช้แบบสอบถามด้านล่าง

SELECT c.name AS 'Column Name',
       t.name + '(' + cast(c.max_length as varchar(50)) + ')' As 'DataType',
       case 
         WHEN  c.is_nullable = 0 then 'null' else 'not null'
         END AS 'Constraint'
  FROM sys.columns c
  JOIN sys.types t
    ON c.user_type_id = t.user_type_id
 WHERE c.object_id    = Object_id('TableName')

คุณจะพบผลลัพธ์ที่แสดงด้านล่าง

ป้อนคำอธิบายรูปภาพที่นี่

ขอบคุณ.


1
เงื่อนไขข้อ จำกัด ของคุณควรเป็นวิธีอื่น
อัลเลน

0
SELECT  
   T.NAME AS [TABLE NAME]
   ,C.NAME AS [COLUMN NAME]
   ,P.NAME AS [DATA TYPE]
   ,P.MAX_LENGTH AS [Max_SIZE]
   ,C.[max_length] AS [ActualSizeUsed]
   ,CAST(P.PRECISION AS VARCHAR) +'/'+ CAST(P.SCALE AS VARCHAR) AS [PRECISION/SCALE]
FROM SYS.OBJECTS AS T
JOIN SYS.COLUMNS AS C
    ON T.OBJECT_ID = C.OBJECT_ID
JOIN SYS.TYPES AS P
    ON C.SYSTEM_TYPE_ID = P.SYSTEM_TYPE_ID
    AND C.[user_type_id] = P.[user_type_id]
WHERE T.TYPE_DESC='USER_TABLE'
  AND T.name = 'InventoryStatus'
ORDER BY 2

1
โปรดใช้การเยื้องแทนมาร์กอัปแบบอินไลน์และเพิ่มคำอธิบายลงในคำตอบของคุณ
Toxantron

ทำไมต้องสั่งซื้อ 2
reggaeguitar

0

ป้อนคำอธิบายรูปภาพที่นี่

ข้อความค้นหา: EXEC SP_DESCRIBE_FIRST_RESULT_SET N'SELECT ANNUAL_INCOME จาก [BSLID2C]. [DBO]. [EMPLOYEE] '

หมายเหตุ: ในบาง IDE ก่อนที่จะเลือก N ทำงานหรือในบาง IDE โดยไม่ทำงาน


0

ไม่มีคีย์หลักที่นี่ แต่สามารถช่วยผู้ใช้รายอื่นที่ต้องการมีชื่อตารางที่มีชื่อเขตข้อมูลและคุณสมบัติเขตข้อมูลพื้นฐาน

USE [**YourDB**]
GO
SELECT tbl.name, fld.[Column Name],fld.[Constraint],fld.DataType 
FROM sys.all_objects as tbl left join 
(SELECT c.OBJECT_ID,  c.name AS 'Column Name',
       t.name + '(' + cast(c.max_length as varchar(50)) + ')' As 'DataType',
       case 
         WHEN  c.is_nullable = 0 then 'null' else 'not null'
         END AS 'Constraint'
  FROM sys.columns c
  JOIN sys.types t
    ON c.user_type_id = t.user_type_id
) as fld on tbl.OBJECT_ID = fld.OBJECT_ID
WHERE ( tbl.[type]='U' and tbl.[is_ms_shipped] = 0)
ORDER BY tbl.[name],fld.[Column Name]
GO

-1

ฉันเพิ่งทำ marc_s "การนำเสนอพร้อม":

SELECT 
    c.name 'Column Name',
    t.name 'Data type',
    IIF(t.name = 'nvarchar', c.max_length / 2, c.max_length) 'Max Length',
    c.precision 'Precision',
    c.scale 'Scale',
    IIF(c.is_nullable = 0, 'No', 'Yes') 'Nullable',
    IIF(ISNULL(i.is_primary_key, 0) = 0, 'No', 'Yes') 'Primary Key'
FROM    
    sys.columns c
INNER JOIN 
    sys.types t ON c.user_type_id = t.user_type_id
LEFT OUTER JOIN 
    sys.index_columns ic ON ic.object_id = c.object_id AND ic.column_id = c.column_id
LEFT OUTER JOIN 
    sys.indexes i ON ic.object_id = i.object_id AND ic.index_id = i.index_id
WHERE
    c.object_id = OBJECT_ID('YourTableName')
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.