[sql] 데이터 형식, NOT NULL 및 PRIMARY KEY 제약 조건과 함께 테이블의 열 목록을 가져 오는 SQL Server 쿼리

특정 테이블의 열 목록, 관련 데이터 유형 (길이) 및 null이 아닌 경우 SQL 서버에 쿼리를 작성해야합니다. 그리고 나는 이것을 많이했습니다.

그러나 이제는 동일한 테이블에서 열에 대해 가져와야합니다- TRUE해당 열이 기본 키인 경우.

어떻게해야합니까?

내 예상 출력은 다음과 같습니다

Column name | Data type | Length | isnull | Pk



답변

일부 열의 중복 행을 피하려면 system_type_id 대신 user_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 이상에서 작동합니다.

당신이 스키마를 사용하는 경우, 교체 YourTableNameYourSchemaName.YourTableName어디에 YourSchemaName실제 스키마 이름이고 YourTableName실제 테이블의 이름입니다.


답변

저장 프로 시저 sp_columns는 자세한 테이블 정보를 반환합니다.

exec sp_columns MyTable


답변

쿼리를 사용할 수 있습니다.

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

Pk 정보를 제외한 필요한 모든 메타 데이터를 가져옵니다.


답변

SQL 2012에서는 다음을 사용할 수 있습니다.

EXEC sp_describe_first_result_set N'SELECT * FROM [TableName]'

열 이름과 속성이 표시됩니다.


답변

이 시도:

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


답변

올바른 길이를 얻으려면 유니 코드 유형을 특수한 경우로 고려해야합니다. 아래 코드를 참조하십시오.

자세한 내용은 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')


답변

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'