На протяжении последних уроков мы создавали значения первичных ключей самостоятельно. Так можно делать в учебных целях, но в промышленной разработке эту задачу берут на себя базы данных. Общий принцип механизма автогенерации такой: внутри базы к каждой таблице создаётся и привязывается отдельный счётчик, который увеличивается на единицу при вставке новой строки, а получившееся значение записывается в то поле, которое помечено как автогенерируемое.
До определённого момента механизм автоинкремента в каждой СУБД был реализован по-своему, иногда значительно отличающимися способами. Это создавало проблемы при переходе от одной СУБД к другой и усложняло реализацию программного слоя доступа к базе данных. Причём эта функциональность добавлена в стандарт SQL:2003, то есть очень давно. И только в 2018 году PostgreSQL (начиная с версии 10) стал его поддерживать. Такой автоинкремент известен под именем GENERATED AS IDENTITY:
CREATE TABLE colors (
-- Одновременное использование и первичного ключа и автогенерации
id bigint PRIMARY KEY GENERATED ALWAYS AS IDENTITY,
name varchar(255)
);
INSERT INTO colors (name) VALUES ('Red'), ('Blue');
SELECT * FROM colors;
Этот запрос вернёт:
id | name |
---|---|
1 | Red |
2 | Blue |
Интересно поведение автогенератора при удалении записей. Если удалить запись с id
равным двум и вставить ещё одну запись, то значением поля id
будет 3
. Автогенерация никак не связана с данными в таблице. Это отдельный счётчик, который всегда увеличивается. Таким образом избегаются вероятные коллизии и ошибки, когда один и тот же идентификатор принадлежит сначала одной записи, а потом другой.
Вот его структура из документации:
column_name type GENERATED { ALWAYS | BY DEFAULT } AS IDENTITY[ ( sequence_option ) ]
GENERATED ALWAYS
— не позволит добавлять значение самостоятельно, используя UPDATE
или INSERT
GENERATED BY DEFAULT
— в отличие от предыдущего варианта, этот вариант позволяет добавлять значения самостоятельноPostgreSQL позволяет иметь более одного автогенерируемого поля на таблицу.
Вам ответят команда поддержки Хекслета или другие студенты.
Выделите текст, нажмите ctrl + enter и отправьте его нам. В течение нескольких дней мы исправим ошибку или улучшим формулировку.
Загляните в раздел «Обсуждение»:
Профессиональная подписка откроет полный доступ ко всем курсам, упражнениям и урокам Хекслета, проектам и пожизненный доступ к теории пройденных уроков. Подписку можно отменить в любой момент.
Курсы программирования для новичков и опытных разработчиков. Начните обучение бесплатно.
Наши выпускники работают в компаниях:
Зарегистрируйтесь или войдите в свой аккаунт