Удаление заказов по выборке средствами API и работы с объектами
Материал из Umicms
Версия от 09:09, 5 июня 2013; Mad grant (обсуждение | вклад)
Актуально для версии 2.9
Перед работой с удалением заказов необходимо сделать полный дамп базы данных.
Так как в административной панели удаление заказов возможно только вручную, при накоплении нескольких тысяч заказов, их удаление будет проблематичным.
В качестве примера, рассмотрим как произвести удаление всех заказов, сделанных ранее заданного года и месяца. Для этого необходимо написать следующий кастом, откроем ~\clases\modules\custom.php. и поместим в него код:
public function delOrders($m=0,$y=0){
$orders = new selector('objects');
$objectsCollection = umiObjectsCollection::getInstance();
$orders->types('object-type')->name('emarket','order');
foreach($orders as $order){
$date=$order->order_date;
echo $order->id."<br />";
$parsDate=explode('-',$date);
if(($parsDate[0]<$y)){
$objectsCollection->delObject($order->id);
}
if(($parsDate[1]<$m)){
$objectsCollection->delObject($order->id);
}
if((!$parsDate[0])&&(!$parsDate[1])){
$objectsCollection->delObject($order->id);
}
}
return "done";
}
где m и y это месяц и год соответственно.