Consulta del servidor SQL para obtener la lista de columnas de una tabla junto con los tipos de datos, NOT NULL y las restricciones PRIMARY KEY

Resuelto Shrayas asked hace 14 años • 20 respuestas

Necesito escribir una consulta en el servidor SQL para obtener la lista de columnas de una tabla en particular, sus tipos de datos asociados (con longitud) y si no son nulos. Y he logrado hacer mucho.

Pero ahora también necesito buscar, en la misma tabla, una columna, TRUEsi esa columna es una clave principal.

¿Cómo hago esto?

Mi resultado esperado es:

Column name | Data type | Length | isnull | Pk
Shrayas avatar Mar 10 '10 23:03 Shrayas
Aceptado

Para evitar filas duplicadas en algunas columnas, utilice user_type_id en lugar de 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')

Simplemente reemplácelo YourTableNamecon el nombre de su tabla real; funciona para SQL Server 2005 y versiones posteriores.

En caso de que esté utilizando esquemas, reemplácelo YourTableName por YourSchemaName.YourTableNamedonde YourSchemaNameestá el nombre real del esquema y YourTableNameel nombre real de la tabla.

marc_s avatar Mar 10 '2010 16:03 marc_s

El procedimiento almacenado sp_columns devuelve información detallada de la tabla.

exec sp_columns MyTable
decompiled avatar Mar 10 '2010 17:03 decompiled