From fea503b8e14587835ae6da1611cb92be62bc4e51 Mon Sep 17 00:00:00 2001 From: Ilmari Karonen Date: Wed, 3 Mar 2010 20:23:42 +0000 Subject: [PATCH] (bug 18881) add maintenance script to populate rev_len field for old revisions --- maintenance/populateRevisionLength.php | 92 ++++++++++++++++++++++++++ 1 file changed, 92 insertions(+) create mode 100644 maintenance/populateRevisionLength.php diff --git a/maintenance/populateRevisionLength.php b/maintenance/populateRevisionLength.php new file mode 100644 index 0000000000..b0c1d04e3a --- /dev/null +++ b/maintenance/populateRevisionLength.php @@ -0,0 +1,92 @@ +mDescription = "Populates rev_len"; + $this->setBatchSize( 200 ); + } + + public function execute() { + $db = wfGetDB( DB_MASTER ); + if ( !$db->tableExists( 'revision' ) ) { + $this->error( "revision table does not exist", true ); + } + $this->output( "Populating rev_len column\n" ); + $start = $db->selectField( 'revision', 'MIN(rev_id)', false, __FUNCTION__ ); + $end = $db->selectField( 'revision', 'MAX(rev_id)', false, __FUNCTION__ ); + if( is_null( $start ) || is_null( $end ) ){ + $this->output( "...revision table seems to be empty.\n" ); + $db->insert( 'updatelog', + array( 'ul_key' => 'populate rev_len' ), + __METHOD__, + 'IGNORE' ); + return; + } + # Do remaining chunks + $blockStart = intval( $start ); + $blockEnd = intval( $start ) + $this->mBatchSize - 1; + $count = 0; + while( $blockStart <= $end ) { + $this->output( "...doing rev_id from $blockStart to $blockEnd\n" ); + $res = $db->select( 'revision', + Revision::selectFields(), + array( "rev_id >= $blockStart", + "rev_id <= $blockEnd", + "rev_len IS NULL" ), + __METHOD__ ); + # Go through and update rev_len from these rows. + foreach( $res as $row ) { + $rev = new Revision( $row ); + $text = $rev->getRawText(); + # Update the row... + $db->update( 'revision', + array( 'rev_len' => strlen( $text ) ), + array( 'rev_id' => $row->rev_id ), + __METHOD__ ); + $count++; + } + $blockStart += $this->mBatchSize; + $blockEnd += $this->mBatchSize; + wfWaitForSlaves( 5 ); + } + $logged = $db->insert( 'updatelog', + array( 'ul_key' => 'populate rev_len' ), + __METHOD__, + 'IGNORE' ); + if( $logged ) { + $this->output( "rev_len population complete ... {$count} rows changed\n" ); + return true; + } else { + $this->output( "Could not insert rev_len population row.\n" ); + return false; + } + } +} + +$maintClass = "PopulateRevisionLength"; +require_once( DO_MAINTENANCE ); -- 2.20.1