DDL / СхемаНачальный
CREATE TABLE
Создаёт новую таблицу с определёнными колонками и ограничениями.
Синтаксис
CREATE TABLE table_name ( column_name data_type [constraints], ... );
Объяснение
CREATE TABLE определяет структуру таблицы: колонки, типы данных, ограничения (NOT NULL, UNIQUE, CHECK, PRIMARY KEY, FOREIGN KEY).
В PostgreSQL рекомендуется:
- id: BIGINT GENERATED ALWAYS AS IDENTITY (вместо SERIAL)
- created_at: TIMESTAMPTZ (с часовым поясом)
- Явные NOT NULL где нужно
Пример
CREATE TABLE users ( id BIGINT GENERATED ALWAYS AS IDENTITY PRIMARY KEY, email VARCHAR(255) NOT NULL UNIQUE, name TEXT NOT NULL, is_active BOOLEAN NOT NULL DEFAULT true, created_at TIMESTAMPTZ NOT NULL DEFAULT NOW() );
Связанные термины
ALTER TABLEИзменяет структуру существующей таблицы: добавляет колонки, меняет типы, добавляет ограничения.FOREIGN KEYОграничение, связывающее колонку с первичным ключом другой таблицы. Обеспечивает ссылочную целостность.PRIMARY KEYУникальный идентификатор строки. Автоматически создаёт уникальный индекс, не допускает NULL.Типы данныхОпределяют какие значения можно хранить в колонке и как они обрабатываются.
Анекдоты по теме
— Почему оконные функции не ходят на свидания вслепую? — Потому что им нужно знать OVER (PARTITION BY кто_пришёл ORDER BY красота DESC), иначе они не знают, как себя вести.
— Чем VARCHAR(255) отличается от TEXT? — В PostgreSQL — почти ничем по производительности. — Тогда зачем VARCHAR(255)? — Традиция. И ограничение длины, если оно нужно.
Как SELECT успокаивает нервы? — Ставит DISTINCT. Теперь он видит только уникальные проблемы.