%PDF- %PDF-
Direktori : /www/varak.net/wiki.varak.net/includes/libs/rdbms/database/ |
Current File : /www/varak.net/wiki.varak.net/includes/libs/rdbms/database/IMaintainableDatabase.php |
<?php /** * This file deals with database interface functions * and query specifics/optimisations. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License along * with this program; if not, write to the Free Software Foundation, Inc., * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * http://www.gnu.org/copyleft/gpl.html * * @file */ namespace Wikimedia\Rdbms; use Exception; use RuntimeException; /** * Advanced database interface for IDatabase handles that include maintenance methods * * This is useful for type-hints used by installer, upgrader, and background scripts * that will make use of lower-level and longer-running queries, including schema changes. * * @ingroup Database * @since 1.28 */ interface IMaintainableDatabase extends IDatabase { /** * Format a table name ready for use in constructing an SQL query * * This does two important things: it quotes the table names to clean them up, * and it adds a table prefix if only given a table name with no quotes. * * All functions of this object which require a table name call this function * themselves. Pass the canonical name to such functions. This is only needed * when calling query() directly. * * @note This function does not sanitize user input. It is not safe to use * this function to escape user input. * @param string $name Database table name * @param string $format One of: * quoted - Automatically pass the table name through addIdentifierQuotes() * so that it can be used in a query. * raw - Do not add identifier quotes to the table name * @return string Full database name */ public function tableName( $name, $format = 'quoted' ); /** * Fetch a number of table names into an array * This is handy when you need to construct SQL for joins * * Example: * list( $user, $watchlist ) = $dbr->tableNames( 'user', 'watchlist' ) ); * $sql = "SELECT wl_namespace, wl_title FROM $watchlist, $user * WHERE wl_user=user_id AND wl_user=$nameWithQuotes"; * * @return array */ public function tableNames(); /** * Fetch a number of table names into an zero-indexed numerical array * This is handy when you need to construct SQL for joins * * Example: * list( $user, $watchlist ) = $dbr->tableNamesN( 'user', 'watchlist' ); * $sql = "SELECT wl_namespace,wl_title FROM $watchlist,$user * WHERE wl_user=user_id AND wl_user=$nameWithQuotes"; * * @return array */ public function tableNamesN(); /** * Returns the size of a text field, or -1 for "unlimited" * * @param string $table * @param string $field * @return int */ public function textFieldSize( $table, $field ); /** * Read and execute SQL commands from a file. * * Returns true on success, error string or exception on failure (depending * on object's error ignore settings). * * @param string $filename File name to open * @param callable|null $lineCallback Optional function called before reading each line * @param callable|null $resultCallback Optional function called for each MySQL result * @param bool|string $fname Calling function name or false if name should be * generated dynamically using $filename * @param callable|null $inputCallback Optional function called for each * complete line sent * @return bool|string * @throws Exception */ public function sourceFile( $filename, callable $lineCallback = null, callable $resultCallback = null, $fname = false, callable $inputCallback = null ); /** * Read and execute commands from an open file handle. * * Returns true on success, error string or exception on failure (depending * on object's error ignore settings). * * @param resource $fp File handle * @param callable|null $lineCallback Optional function called before reading each query * @param callable|null $resultCallback Optional function called for each MySQL result * @param string $fname Calling function name * @param callable|null $inputCallback Optional function called for each complete query sent * @return bool|string */ public function sourceStream( $fp, callable $lineCallback = null, callable $resultCallback = null, $fname = __METHOD__, callable $inputCallback = null ); /** * Called by sourceStream() to check if we've reached a statement end * * @param string &$sql SQL assembled so far * @param string &$newLine New line about to be added to $sql * @return bool Whether $newLine contains end of the statement */ public function streamStatementEnd( &$sql, &$newLine ); /** * Delete a table * @param string $tableName * @param string $fName * @return bool|ResultWrapper */ public function dropTable( $tableName, $fName = __METHOD__ ); /** * Perform a deadlock-prone transaction. * * This function invokes a callback function to perform a set of write * queries. If a deadlock occurs during the processing, the transaction * will be rolled back and the callback function will be called again. * * Avoid using this method outside of Job or Maintenance classes. * * Usage: * $dbw->deadlockLoop( callback, ... ); * * Extra arguments are passed through to the specified callback function. * This method requires that no transactions are already active to avoid * causing premature commits or exceptions. * * Returns whatever the callback function returned on its successful, * iteration, or false on error, for example if the retry limit was * reached. * * @return mixed * @throws DBUnexpectedError * @throws Exception */ public function deadlockLoop(); /** * Lists all the VIEWs in the database * * @param string|null $prefix Only show VIEWs with this prefix, eg. unit_test_ * @param string $fname Name of calling function * @throws RuntimeException * @return array */ public function listViews( $prefix = null, $fname = __METHOD__ ); /** * Creates a new table with structure copied from existing table * * Note that unlike most database abstraction functions, this function does not * automatically append database prefix, because it works at a lower abstraction level. * The table names passed to this function shall not be quoted (this function calls * addIdentifierQuotes() when needed). * * @param string $oldName Name of table whose structure should be copied * @param string $newName Name of table to be created * @param bool $temporary Whether the new table should be temporary * @param string $fname Calling function name * @return bool True if operation was successful * @throws RuntimeException */ public function duplicateTableStructure( $oldName, $newName, $temporary = false, $fname = __METHOD__ ); /** * Checks if table locks acquired by lockTables() are transaction-bound in their scope * * Transaction-bound table locks will be released when the current transaction terminates. * Table locks that are not bound to a transaction are not effected by BEGIN/COMMIT/ROLLBACK * and will last until either lockTables()/unlockTables() is called or the TCP connection to * the database is closed. * * @return bool * @since 1.29 */ public function tableLocksHaveTransactionScope(); /** * Lock specific tables * * Any pending transaction should be resolved before calling this method, since: * a) Doing so resets any REPEATABLE-READ snapshot of the data to a fresh one. * b) Previous row and table locks from the transaction or session may be released * by LOCK TABLES, which may be unsafe for the changes in such a transaction. * c) The main use case of lockTables() is to avoid deadlocks and timeouts by locking * entire tables in order to do long-running, batched, and lag-aware, updates. Batching * and replication lag checks do not work when all the updates happen in a transaction. * * Always get all relevant table locks up-front in one call, since LOCK TABLES might release * any prior table locks on some RDBMes (e.g MySQL). * * For compatibility, callers should check tableLocksHaveTransactionScope() before using * this method. If locks are scoped specifically to transactions then caller must either: * - a) Start a new transaction and acquire table locks for the scope of that transaction, * doing all row updates within that transaction. It will not be possible to update * rows in batches; this might result in high replication lag. * - b) Forgo table locks entirely and avoid calling this method. Careful use of hints like * LOCK IN SHARE MODE and FOR UPDATE and the use of query batching may be preferrable * to using table locks with a potentially large transaction. Use of MySQL and Postges * style REPEATABLE-READ (Snapshot Isolation with or without First-Committer-Rule) can * also be considered for certain tasks that require a consistent view of entire tables. * * If session scoped locks are not supported, then calling lockTables() will trigger * startAtomic(), with unlockTables() triggering endAtomic(). This will automatically * start a transaction if one is not already present and cause the locks to be released * when the transaction finishes (normally during the unlockTables() call). * * In any case, avoid using begin()/commit() in code that runs while such table locks are * acquired, as that breaks in case when a transaction is needed. The startAtomic() and * endAtomic() methods are safe, however, since they will join any existing transaction. * * @param array $read Array of tables to lock for read access * @param array $write Array of tables to lock for write access * @param string $method Name of caller * @return bool * @since 1.29 */ public function lockTables( array $read, array $write, $method ); /** * Unlock all tables locked via lockTables() * * If table locks are scoped to transactions, then locks might not be released until the * transaction ends, which could happen after this method is called. * * @param string $method The caller * @return bool * @since 1.29 */ public function unlockTables( $method ); /** * List all tables on the database * * @param string|null $prefix Only show tables with this prefix, e.g. mw_ * @param string $fname Calling function name * @throws DBError * @return array */ public function listTables( $prefix = null, $fname = __METHOD__ ); /** * Determines if a given index is unique * * @param string $table * @param string $index * * @return bool */ public function indexUnique( $table, $index ); /** * mysql_fetch_field() wrapper * Returns false if the field doesn't exist * * @param string $table Table name * @param string $field Field name * * @return Field */ public function fieldInfo( $table, $field ); } class_alias( IMaintainableDatabase::class, 'IMaintainableDatabase' );