當前位置: 首頁>>代碼示例>>PHP>>正文


PHP Connection::rollback方法代碼示例

本文整理匯總了PHP中OC\DB\Connection::rollback方法的典型用法代碼示例。如果您正苦於以下問題:PHP Connection::rollback方法的具體用法?PHP Connection::rollback怎麽用?PHP Connection::rollback使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在OC\DB\Connection的用法示例。


在下文中一共展示了Connection::rollback方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: run

 /**
  * Converts legacy home storage ids in the format
  * "local::/data/dir/path/userid/" to the new format "home::userid"
  */
 public function run()
 {
     // only run once
     if ($this->config->getAppValue('core', 'repairlegacystoragesdone') === 'yes') {
         return;
     }
     $dataDir = $this->config->getSystemValue('datadirectory', \OC::$SERVERROOT . '/data/');
     $dataDir = rtrim($dataDir, '/') . '/';
     $dataDirId = 'local::' . $dataDir;
     $count = 0;
     $this->connection->beginTransaction();
     try {
         // note: not doing a direct UPDATE with the REPLACE function
         // because regexp search/extract is needed and it is not guaranteed
         // to work on all database types
         $sql = 'SELECT `id`, `numeric_id` FROM `*PREFIX*storages`' . ' WHERE `id` LIKE ?' . ' ORDER BY `id`';
         $result = $this->connection->executeQuery($sql, array($dataDirId . '%'));
         while ($row = $result->fetch()) {
             $currentId = $row['id'];
             // one entry is the datadir itself
             if ($currentId === $dataDirId) {
                 continue;
             }
             if ($this->fixLegacyStorage($currentId, (int) $row['numeric_id'])) {
                 $count++;
             }
         }
         // check for md5 ids, not in the format "prefix::"
         $sql = 'SELECT COUNT(*) AS "c" FROM `*PREFIX*storages`' . ' WHERE `id` NOT LIKE \'%::%\'';
         $result = $this->connection->executeQuery($sql);
         $row = $result->fetch();
         // find at least one to make sure it's worth
         // querying the user list
         if ((int) $row['c'] > 0) {
             $userManager = \OC_User::getManager();
             // use chunks to avoid caching too many users in memory
             $limit = 30;
             $offset = 0;
             do {
                 // query the next page of users
                 $results = $userManager->search('', $limit, $offset);
                 $storageIds = array();
                 $userIds = array();
                 foreach ($results as $uid => $userObject) {
                     $storageId = $dataDirId . $uid . '/';
                     if (strlen($storageId) <= 64) {
                         // skip short storage ids as they were handled in the previous section
                         continue;
                     }
                     $storageIds[$uid] = $storageId;
                 }
                 if (count($storageIds) > 0) {
                     // update the storages of these users
                     foreach ($storageIds as $uid => $storageId) {
                         $numericId = \OC\Files\Cache\Storage::getNumericStorageId($storageId);
                         if (!is_null($numericId) && $this->fixLegacyStorage($storageId, (int) $numericId)) {
                             $count++;
                         }
                     }
                 }
                 $offset += $limit;
             } while (count($results) >= $limit);
         }
         $this->emit('\\OC\\Repair', 'info', array('Updated ' . $count . ' legacy home storage ids'));
         $this->connection->commit();
     } catch (\OC\RepairException $e) {
         $this->connection->rollback();
         throw $e;
     }
     $this->config->setAppValue('core', 'repairlegacystoragesdone', 'yes');
 }
開發者ID:samj1912,項目名稱:repo,代碼行數:75,代碼來源:repairlegacystorages.php


注:本文中的OC\DB\Connection::rollback方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。