wiki.techinc.nl/maintenance/benchmarks/benchmarkTruncate.php
Aaron Schulz 1dd273b8ff Replace use of "unquoted" with "raw" for tableName() callers
Change-Id: I4fed3a901ef212b1f502e7f90ecd6cf3dc1295f0
2023-11-21 10:43:10 -08:00

55 lines
1.6 KiB
PHP

<?php
require_once __DIR__ . '/../includes/Benchmarker.php';
/**
* Maintenance script that benchmarks TRUNCATE versus DELETE queries.
*
* @ingroup Benchmark
*/
class BenchmarkTruncate extends Benchmarker {
public function execute() {
$fname = __METHOD__;
$dbw = $this->getDB( DB_PRIMARY );
$dbw->dropTable( 'benchmark_perm_test' );
$permTable = $dbw->tableName( 'benchmark_perm_test', 'raw' );
$dbw->duplicateTableStructure(
$dbw->tableName( 'page', 'raw' ),
$permTable,
false,
$fname
);
$dbw->dropTable( 'benchmark_temp_test' );
$tempTable = $dbw->tableName( 'benchmark_temp_test', 'raw' );
$dbw->duplicateTableStructure(
$dbw->tableName( 'page', 'raw' ),
$tempTable,
true,
$fname
);
$this->bench( [
'perm truncate' => static function () use ( $dbw, $fname, $permTable ) {
$dbw->query( "TRUNCATE $permTable", $fname );
},
'perm delete' => static function () use ( $dbw, $fname, $permTable ) {
$dbw->query( "DELETE FROM $permTable", $fname );
},
'temp truncate' => static function () use ( $dbw, $fname, $tempTable ) {
// Use a raw query not truncate() to avoid the "pristine" check.
// The other cases also use query() so that they will have comparable overhead.
$dbw->query( "TRUNCATE $tempTable", $fname );
},
'temp delete' => static function () use ( $dbw, $fname, $tempTable ) {
$dbw->query( "DELETE FROM $tempTable", $fname );
}
] );
$dbw->dropTable( 'benchmark_perm_test', $fname );
$dbw->dropTable( 'benchmark_temp_test', $fname );
}
}
$maintClass = BenchmarkTruncate::class;
require_once RUN_MAINTENANCE_IF_MAIN;