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 'Запрещено удалять книгу, так как по ней есть заказ';
}
Пример 2
Условие
Аналогично Примеру 1.
Нужно создать действие, которое очистит заказ, удалив все его строки.
Решение
clear (Order o) {
// Вариант 1
DELETE OrderDetail d WHERE order(d) == o;
// Вариант 2
FOR order(OrderDetail d) == o DO
DELETE d;
}
Оба варианта равносильны с точки зрения выполнения.