sql >> Databáze >  >> RDS >> Sqlserver

Dotaz serveru SQL pro získání seznamu sloupců v tabulce spolu s omezeními typu dat, NOT NULL a PRIMARY KEY

Chcete-li se vyhnout duplicitním řádkům pro některé sloupce, použijte místo 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')

Stačí nahradit YourTableName se skutečným názvem tabulky – funguje pro SQL Server 2005 a vyšší.

V případě, že používáte schémata, nahraďte YourTableName od YourSchemaName.YourTableName kde YourSchemaName je skutečný název schématu a YourTableName je skutečný název tabulky.



  1. Změňte sloupce PostgreSQL používané v pohledech

  2. Jak změnit typ dat sloupce v SQL Server (T-SQL)

  3. Jak získat krátký název měsíce z data v MariaDB

  4. Entity Framework 6 – Časové dotazy