Здравствуйте, нужно обновить определённое свойство, а точнее его перезаписать так как с 1С приходят данные с запятой, а нужны в общем то с точкой. Написал следующий скрипт, но не нашёл в Апи битрикса как записать 1 запросом данные, я так понимаю на каждый setProperyValueEx и Update идёт запрос к базе, ну следовательно вылезает что время запроса к базе превышено и скрипт выполняется не полностью. Если поставить время запроса больше то отваливается апач от браузера, тестил на локальном сервере. Подскажите как это всё грамотно сделать пожалуйста.
Код |
---|
if(CModule::IncludeModule("iblock")){
$id_catalog = 8;
$prop = [];
$order = ['ID' => 'ASC'];
$filter = ['IBLOCK_ID' => $id_catalog];
$rows = CIBlockElement::GetList($order, $filter);
while ($row = $rows->fetch()) {
$row['PROPERTIES'] = [];
$prop[$row['ID']] =& $row;
unset($row);
}
//Получаю массив со всеми свойствами всех элементов
CIBlockElement::GetPropertyValuesArray($prop, $filter['IBLOCK_ID'], $filter);
unset($rows, $filter, $order);
//перезаписываю в массив $arCodeValue нужное свойство
$arCodeValue = [];
foreach ($prop as $key => $value) {
if(!empty($value)){
while(strstr($value['PROPERTIES']['VOLUME']['VALUE'], ',')){
$value['PROPERTIES']['VOLUME']['VALUE'] = str_replace(',','.',$value['PROPERTIES']['VOLUME']['VALUE']);
$arCodeValue[$key] = [$value['PROPERTIES']['VOLUME']['ID'] => $value['PROPERTIES']['VOLUME']['VALUE']];
}
}else echo 'empty';
}
//До этого всё выполняется быстро, а последний цикл как раз даёт много запросов бд
//Записываю массив $arCodeValue при помощи SetPropertyValuesEx
//Сохраняю при помощи Update
foreach ($prop as $key => $value) {
if(!empty($value) && strstr($value['PROPERTIES']['VOLUME']['VALUE'], ',')){
CIBlockElement::SetPropertyValuesEx($key, $id_catalog, $arCodeValue[$key]);
$elthis = new CIBlockElement;
$elthis->Update(
$key,
[ 'WF_STATUS_ID' => 1, 'ACTIVE' => 'Y' ],
true
);
echo $key;
echo ' ';
unset($elthis);
}
}
}
|