Логотип YeaHub

База вопросов

Собеседования

Тренажёр

База ресурсов

Обучение

Навыки

Задачи

Войти

Выбери, каким будет IT завтра — вместе c нами!

YeaHub — это полностью открытый проект, призванный объединить и улучшить IT-сферу. Наш исходный код доступен для просмотра на GitHub. Дизайн проекта также открыт для ознакомления в Figma.

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Postgres: database, constraints

Констрейнты в БД

Вопрос проверяет знание ограничений (constraints) в базах данных, их типов и назначения для обеспечения целостности данных.

Короткий ответ

Констрейнты — это правила, которые ограничивают данные в таблицах БД для обеспечения их целостности. Основные типы: PRIMARY KEY, FOREIGN KEY, UNIQUE, NOT NULL, CHECK. Они предотвращают некорректные операции с данными.

Длинный ответ

Констрейнты (ограничения) — это механизм обеспечения целостности данных в реляционных базах данных.

Основные типы констрейнтов:

  1. PRIMARY KEY — уникальный идентификатор строки:

    • Гарантирует уникальность и отсутствие NULL значений

    • Пример: id INT PRIMARY KEY

  2. FOREIGN KEY — связь между таблицами:

    • Обеспечивает ссылочную целостность

    • Пример: FOREIGN KEY (user_id) REFERENCES users(id)

  3. UNIQUE — уникальность значений в столбце:

    • Разрешает NULL значения (если не combined with NOT NULL)

    • Пример: email VARCHAR(255) UNIQUE

  4. NOT NULL — запрет пустых значений:

    • Пример: name VARCHAR(100) NOT NULL

  5. CHECK — проверка условий для значений:

    • Пример: age INT CHECK (age >= 0)

Пример создания таблицы с констрейнтами:

CREATE TABLE employees (
    id INT PRIMARY KEY,
    email VARCHAR(255) UNIQUE NOT NULL,
    department_id INT,
    salary DECIMAL(10,2) CHECK (salary > 0),
    FOREIGN KEY (department_id) REFERENCES departments(id)
);

Преимущества использования:

  • Гарантируют корректность данных

  • Предотвращают дублирование записей

  • Обеспечивают согласованность связанных данных

  • Упрощают логику приложения

  • Аватар

    Golang Guru

    Maxim Lukyanov

    Guru – это эксперты YeaHub, которые помогают развивать комьюнити.

Уровень

  • Рейтинг:

    3

  • Сложность:

    8

Навыки

  • Postgres

    Postgres

Ключевые слова

#database

#constraints

Подпишись на Python Developer в телеграм

  • Аватар

    Golang Guru

    Maxim Lukyanov

    Guru – это эксперты YeaHub, которые помогают развивать комьюнити.