В разных филиалах компании собираются заказы, которые периодически отправляются в центральный офис. Чтобы обеспечить уникальность идентификатора заказа используем UUID.
# в разных филиалах происходит наполнение таблицы orders и order_details
# добавляем запись о заказе
^void:sql{
insert into orders
(order_uuid, date_ordered, total)
values
('$order_uuid', '$date_ordered', $total)
}
#цикл по заказанным продуктам вокруг добавления записи о продукте
^void:sql{
# с какой-то периодичностью выбирается часть таблицы orders (и order_details)
# отправляется (^mail:send[…]) в центральный офис,
# где части таблиц попадают в общие таблицы orders и order_details
# БЕЗ проблем с повторяющимся order_id
Примечание: Parser создает UUID основываясь на случайных числах, а не времени. Параметры:
·
variant = DCE;
·
version = DCE Security version, with embedded POSIX UIDs.
В UUID не все биты случайны, и это так и должно быть:
xxxxxxxx-xxxx-4xxx-{8,9,A,B}xxx-xxxxxxxxxxxx
Подробная информация о UUID доступна здесь: http://www.opengroup.org/onlinepubs/9629399/apdxa.htm