Вычисляемые столбцы Иногда поле в запросе рассчитывают на осн | SQLite на практике
Вычисляемые столбцы
Иногда поле в запросе рассчитывают на основе других столбцов таблицы.
Например, есть столбец income с годовым доходом и tax_rate с налоговой ставкой. Тогда можно посчитать годовой налог:
select
id,
income * tax_rate as tax
from people;
А чтобы не таскать везде эти вычисления, удобно создать виртуальный столбец.
В общем виде синтаксис такой:
alter table ТАБЛИЦА
add column СТОЛБЕЦ ТИП as (ВЫРАЖЕНИЕ);
Для налогов будет так:
alter table people
add column tax real as (
income * tax_rate
);
После этого столбец можно использовать в запросах точно так же, как обычные столбцы:
select id, tax
from people;
Виртуальные столбцы не хранятся в базе и рассчитываются «на лету». Но по ним вполне можно построить индекс, если захотите ускорить выборку.
Строго говоря, в SQLite есть виртуальные (virtual) вычисляемые столбцы и хранимые (stored). Хранимые сохраняются на диске, но создать их через alter table невозможно, поэтому в основном пользуются виртуальными.
Вычисляемые столбцы могут использовать любые столбцы таблицы, но не другие таблицы и не результаты подзапросов. Оно и к лучшему: для более сложных комбинаций есть представления (views) и временные таблицы (temp tables). Но о них как-нибудь в другой раз.