How-to: DELETE
Пример 1
Условие
Есть заказ, с заданной датой и покупателем и строками заказов, которые ссылаются на книги.
CLASS Order 'Заказ';
CLASS Book 'Книга';
name 'Наименование' = DATA ISTRING[50] (Book);
CLASS OrderDetail 'Строка заказа';
order 'Заказ' = DATA Order (OrderDetail) NONULL DELETE;
book 'Книга' = DATA Book (OrderDetail);
nameBook 'Книга' (OrderDetail d) = name(book(d));
Нужно создать действие, которое удалит книгу, если по ней нету заказов.
Решение
delete (Book b) {
IF NOT [ GROUP SUM 1 BY book(OrderDetail d)](b) THEN
DELETE b;
ELSE
MESSAGE 'Запрещено удалять книгу, так как по ней есть заказ';
}