SQL Seznam sloupců s určitým datovým typem – INFORMATION_SCHEMA.COLUMNS

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;

information_schema.columns

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ě

5/5 - (1 vote)
Rubrika: SQL Administrace Užitečné SQL skripty

O Ing. Jan Zedníček - Data Engineer & Controlling

Jmenuji se Honza Zedníček a působím jako data engineer freelancer. Během cca 10 let jsem zde shromáždil přes 600 IT case studies, průvodců, návodů a tipů určených zejména odborné veřejnosti, studentům a zájemcům o informace z oblastí Data Engineeringu, korporátních financí a reportingu. Zaměřuji se především na Microsoft technologie (on-prem i cloud) a různé synergické efekty v rámci jejich produktového portfolia pro dataře a finanční profesionály. Věnuji se také dalším platformám a významným hráčům z oblasti open source technologií. 🔥 Pokud vám tento článek pomohl, ocením referenci na vašem webu nebo zmínku v komunitě. A mám pro vás ještě tip: řešíte-li nějaký zapeklitý Excel problém, přihlašte se do naší Excel Facebook skupiny (2.4k+ členů), kde si pomáháme Excel CZ/SK diskuse ».

Leave a Reply

Your email address will not be published. Required fields are marked *