Перейти к основному содержимому
Версия: 5.x

Предыдущее значение (PREV)

Оператор предыдущего значения создает свойство, которое возвращает значение заданного свойства на начало сессии (то есть текущее значение в базе данных без учета изменений в сессии).

warning

Этот оператор вычисляется по другому внутри обработки событий : в этом случае он возвращает значение на момент предыдущего возникновения этого события (а точнее, окончания выполнения всех его обработок).

Язык

Для объявления свойства, возвращающего предыдущее значение, используется оператор PREV.

Примеры

f = DATA INTEGER (A);
// выдает по очереди все изменения f(a) в сессии
messageFChanges {
FOR CHANGED(f(A a)) DO
MESSAGE 'In this session f(a) changed from ' + PREV(f(a)) + ' TO ' + f(a);
}

CLASS Document;
date = DATA DATE (Document);

CLASS Article;
price = DATA NUMERIC[14,2] (Document, Article);
// записать в цену документа, последнюю использованную цену в БД
// PREV важен чтобы не учитывалась цены введенные в этом документе
// это особенно важно, если последняя использованная цена будет материализованной, тогда платформа сможет просто считать это значение из таблицы
setPrice {
price(Document d, Article a) <- PREV((GROUP LAST price(d, a) ORDER date(d), d));
}