sql >> Database >  >> RDS >> Sqlserver

SQL-serverquery om de lijst met kolommen in een tabel te krijgen, samen met gegevenstypen, NOT NULL en PRIMARY KEY-beperkingen

Gebruik user_type_id in plaats van system_type_id om dubbele rijen voor sommige kolommen te voorkomen.

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')

Vervang gewoon YourTableName met uw werkelijke tabelnaam - werkt voor SQL Server 2005 en hoger.

Als u schema's gebruikt, vervangt u YourTableName door YourSchemaName.YourTableName waar YourSchemaName is de werkelijke schemanaam en YourTableName is de werkelijke tafelnaam.



  1. String_agg voor SQL Server vóór 2017

  2. ALL_PROCEDURES-weergave toont de PROCEDURE_NAME niet

  3. psycopg2 hoe om te gaan met TypeError:niet alle argumenten geconverteerd tijdens het formatteren van strings

  4. Hoe kan ik een MySQL-database initialiseren met schema in een Docker-container?