Denním chlebem db admina je sledovat v jaké kondici se nachází jeho databáze a SQL Server instance. Často je v rámci politiky stanoveno, že některé sloupce musí mít určitý sql datový typ – například že se nesmí z určitých důvodů používat (n)varchar (max) a potřebujeme získat seznam sloupců a datové typy, které se v naší databázi nacházejí.
Dotaz na sloupce a jejich datové typy – INFORMATION_SCHEMA.COLUMNS
Pro tuto úlohu můžeme využít 2 způsoby. Jde to udělat přes INFORMATION_SCHEMA.COLUMNS views nebo systémovou tabulku sys.columns. Zde ukážu variantu přes view.
Rychlý přehled o použitých datových typech sloupců v databázi
Můžeme si např. zobrazit počet sloupců určitého datového typu
SELECT
DATA_TYPE
,COUNT(*) AS [Počet sloupců daného datového typu]
FROM INFORMATION_SCHEMA.COLUMNS
GROUP BY DATA_TYPE
ORDER BY COUNT(*) DESC;
Délka všech %char řetězců a seznam sloupců
Dotaz může vypadat viz. níže. Označené záznamy na obrázku, které mají atribut CHARACTER_MAXIMUM_LENGTH = -1 jsou nvarchary (max)
SELECT
TABLE_CATALOG
,TABLE_NAME
,COLUMN_NAME
,DATA_TYPE
,CHARACTER_MAXIMUM_LENGTH
FROM INFORMATION_SCHEMA.COLUMNS
WHERE DATA_TYPE LIKE ('%char')
ORDER BY CHARACTER_MAXIMUM_LENGTH;
Podobným způsobem se dá zkontrolovat řada dalších atributů sloupců jako je například NULL/NOT NULL (IS_NULLABLE), pozice sloupce (ORDINAL_POSITION), Collation (COLLATION_NAME) a podobně