Server IP : 80.87.202.40 / Your IP : 216.73.216.169 Web Server : Apache System : Linux rospirotorg.ru 5.14.0-539.el9.x86_64 #1 SMP PREEMPT_DYNAMIC Thu Dec 5 22:26:13 UTC 2024 x86_64 User : bitrix ( 600) PHP Version : 8.2.27 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : ON Directory : /home/bitrix/ext_www/rospirotorg.ru/bitrix/modules/pull/lib/internals/ |
Upload File : |
<?php namespace Bitrix\Pull\Internals; use Bitrix\Main\Error; use Bitrix\Main\ORM\Data\UpdateResult; use Bitrix\Main\ORM\Query\Query; trait UpdateByFilterTrait { public static function updateByFilter(array $filter, array $fields): UpdateResult { $result = new UpdateResult(); $entity = static::getEntity(); $sqlTableName = static::getTableName(); $sqlHelper = $entity->getConnection()->getSqlHelper(); $update = $sqlHelper->prepareUpdate($sqlTableName, $fields); try { $where = Query::buildFilterSql($entity, $filter); } catch (\Throwable $e) { return $result->addError(new Error("Could not construct the update query: {$e->getMessage()}")); } if ($where !== '' && $update[0] !== '') { $sql = "UPDATE {$sqlTableName} SET {$update[0]} WHERE {$where}"; $entity->getConnection()->queryExecute($sql); $result->setAffectedRowsCount($entity->getConnection()); static::cleanCache(); } else { $result->addError(new Error("Could not execute the update query")); } return $result; } }