Логотип YeaHub

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

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

Тренажёр

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

Обучение

Навыки

Задачи

Войти

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

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

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Postgres: select star, explicit fields, query plan, bandwidth

Есть ли разница между SELECT * и перечислением полей?

Проверяет понимание того, как выборка полей влияет на запрос.

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

SELECT * возвращает все столбцы таблицы в их текущем порядке, а перечисление полей (SELECT id, name) явным образом указывает, какие именно столбцы нужны. Явный список полей снижает объём передаваемых данных и защищает от неожиданных изменений схемы при добавлении новых столбцов.

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

Объём данных:

  • * может вернуть ненужные большие поля (BLOB, TEXT).

  • Перечисление сокращает трафик между БД и приложением.

Явность:

  • При изменении схемы (добавлении/удалении столбцов) поведение SELECT * меняется.

  • Перечисление полей гарантирует стабильный набор данных.

Оптимизация:

  • Планировщик может точнее оценить стоимость запроса, зная список полей.

Безопасность:

  • Исключает непреднамеренный доступ к конфиденциальным столбцам.

  • Аватар

    Golang Guru

    Maxim Lukyanov

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

Уровень

  • Рейтинг:

    2

  • Сложность:

    7

Навыки

  • Postgres

    Postgres

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

#select star

#explicit fields

#query plan

#bandwidth

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

  • Аватар

    Golang Guru

    Maxim Lukyanov

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