From 8e8057c6fe8c49037d2a04a88df09cce3997f09a Mon Sep 17 00:00:00 2001 From: epriestley Date: Fri, 21 Jun 2013 12:55:07 -0700 Subject: [PATCH] Add LiskRawMigrationIterator Summary: Ref T2222. I need this to migrate the Differential comment tables, because they are large. We have the similar `LiskMigrationIterator` already, but it won't work here because I intend to destroy the original objects after migrating them. Test Plan: Wrote a script to iterate over the `differential_comment` table, got reasonable output: {P869} Reviewers: btrahan Reviewed By: btrahan CC: chad, aran Maniphest Tasks: T2222 Differential Revision: https://secure.phabricator.com/D6264 --- src/__phutil_library_map__.php | 2 + .../storage/lisk/LiskRawMigrationIterator.php | 39 +++++++++++++++++++ 2 files changed, 41 insertions(+) create mode 100644 src/infrastructure/storage/lisk/LiskRawMigrationIterator.php diff --git a/src/__phutil_library_map__.php b/src/__phutil_library_map__.php index ad1b08d1e6..3924ee8e35 100644 --- a/src/__phutil_library_map__.php +++ b/src/__phutil_library_map__.php @@ -626,6 +626,7 @@ phutil_register_library_map(array( 'LiskIsolationTestDAO' => 'infrastructure/storage/lisk/__tests__/LiskIsolationTestDAO.php', 'LiskIsolationTestDAOException' => 'infrastructure/storage/lisk/__tests__/LiskIsolationTestDAOException.php', 'LiskMigrationIterator' => 'infrastructure/storage/lisk/LiskMigrationIterator.php', + 'LiskRawMigrationIterator' => 'infrastructure/storage/lisk/LiskRawMigrationIterator.php', 'ManiphestAction' => 'applications/maniphest/constants/ManiphestAction.php', 'ManiphestAuxiliaryFieldDefaultSpecification' => 'applications/maniphest/auxiliaryfield/ManiphestAuxiliaryFieldDefaultSpecification.php', 'ManiphestAuxiliaryFieldSpecification' => 'applications/maniphest/auxiliaryfield/ManiphestAuxiliaryFieldSpecification.php', @@ -2476,6 +2477,7 @@ phutil_register_library_map(array( 'LiskIsolationTestDAO' => 'LiskDAO', 'LiskIsolationTestDAOException' => 'Exception', 'LiskMigrationIterator' => 'PhutilBufferedIterator', + 'LiskRawMigrationIterator' => 'PhutilBufferedIterator', 'ManiphestAction' => 'ManiphestConstants', 'ManiphestAuxiliaryFieldDefaultSpecification' => 'ManiphestAuxiliaryFieldSpecification', 'ManiphestAuxiliaryFieldSpecification' => 'PhabricatorMarkupInterface', diff --git a/src/infrastructure/storage/lisk/LiskRawMigrationIterator.php b/src/infrastructure/storage/lisk/LiskRawMigrationIterator.php new file mode 100644 index 0000000000..a7edbd7f91 --- /dev/null +++ b/src/infrastructure/storage/lisk/LiskRawMigrationIterator.php @@ -0,0 +1,39 @@ +conn = $conn; + $this->table = $table; + } + + protected function didRewind() { + $this->cursor = 0; + } + + public function key() { + return idx($this->current(), $this->column); + } + + protected function loadPage() { + $page = queryfx_all( + $this->conn, + 'SELECT * FROM %T WHERE %C > %d ORDER BY ID ASC LIMIT %d', + $this->table, + $this->column, + $this->cursor, + $this->getPageSize()); + + if ($page) { + $this->cursor = idx(last($page), $this->column); + } + + return $page; + } + +}