MediaWiki master
IReadableDatabase.php
Go to the documentation of this file.
1<?php
20namespace Wikimedia\Rdbms;
21
22use stdClass;
23use Stringable;
27
34interface IReadableDatabase extends Stringable, ISQLPlatform, DbQuoter, IDatabaseFlags {
35
37 public const UNION_ALL = true;
39 public const UNION_DISTINCT = false;
40
48 public function getServerInfo();
49
56 public function tablePrefix( $prefix = null );
57
64 public function dbSchema( $schema = null );
65
69 public function isOpen();
70
78 public function getDomainID();
79
85 public function getType();
86
92 public function lastErrno();
93
99 public function lastError();
100
108 public function getSoftwareLink();
109
115 public function getServerVersion();
116
130 public function close( $fname = __METHOD__ );
131
143
156
188 public function selectField(
189 $tables, $var, $cond = '', $fname = __METHOD__, $options = [], $join_conds = []
190 );
191
224 public function selectFieldValues(
225 $tables, $var, $cond = '', $fname = __METHOD__, $options = [], $join_conds = []
226 ): array;
227
435 public function select(
436 $tables,
437 $vars,
438 $conds = '',
439 $fname = __METHOD__,
440 $options = [],
441 $join_conds = []
442 );
443
474 public function selectRow(
475 $tables,
476 $vars,
477 $conds,
478 $fname = __METHOD__,
479 $options = [],
480 $join_conds = []
481 );
482
512 public function estimateRowCount(
513 $tables, $var = '*', $conds = '', $fname = __METHOD__, $options = [], $join_conds = []
514 ): int;
515
548 public function selectRowCount(
549 $tables, $var = '*', $conds = '', $fname = __METHOD__, $options = [], $join_conds = []
550 ): int;
551
564 public function databasesAreIndependent();
565
578 public function selectDomain( $domain );
579
585 public function getDBname();
586
592 public function getServer();
593
600 public function getServerName();
601
607 public function ping();
608
617 public function getLag();
618
632 public function getSessionLagStatus();
633
644 public function encodeBlob( $b );
645
655 public function decodeBlob( $b );
656
671 public function expr( string $field, string $op, $value ): Expression;
672
683 public function andExpr( array $conds ): AndExpressionGroup;
684
695 public function orExpr( array $conds ): OrExpressionGroup;
696
704 public function __toString();
705}
Representing a group of expressions chained via AND.
A composite leaf representing an expression.
Representing a group of expressions chained via OR.
Build SELECT queries with a fluent interface.
A query builder for UNION queries takes SelectQueryBuilder objects.
A database connection without write operations.
getSessionLagStatus()
Get a cached estimate of the seconds of replication lag on this database server, using the estimate o...
ping()
Ping the server and try to reconnect if it there is no connection.
close( $fname=__METHOD__)
Close the database connection.
getServerVersion()
A string describing the current software version.
getType()
Get the RDBMS type of the server (e.g.
newSelectQueryBuilder()
Create an empty SelectQueryBuilder which can be used to run queries against this connection.
encodeBlob( $b)
Some DBMSs have a special format for inserting into blob fields, they don't allow simple quoted strin...
getDBname()
Get the current database name; null if there isn't one.
selectDomain( $domain)
Set the current domain (database, schema, and table prefix)
selectField( $tables, $var, $cond='', $fname=__METHOD__, $options=[], $join_conds=[])
A SELECT wrapper which returns a single field from a single result row.
selectRow( $tables, $vars, $conds, $fname=__METHOD__, $options=[], $join_conds=[])
Wrapper to IDatabase::select() that only fetches one row (via LIMIT)
selectRowCount( $tables, $var=' *', $conds='', $fname=__METHOD__, $options=[], $join_conds=[])
Get the number of rows in dataset.
decodeBlob( $b)
Some DBMSs return a special placeholder object representing blob fields in result objects.
dbSchema( $schema=null)
Get/set the db schema.
select( $tables, $vars, $conds='', $fname=__METHOD__, $options=[], $join_conds=[])
Execute a SELECT query constructed using the various parameters provided.
lastErrno()
Get the RDBMS-specific error code from the last attempted query statement.
selectFieldValues( $tables, $var, $cond='', $fname=__METHOD__, $options=[], $join_conds=[])
A SELECT wrapper which returns a list of single field values from result rows.
lastError()
Get the RDBMS-specific error description from the last attempted query statement.
tablePrefix( $prefix=null)
Get/set the table prefix.
getServer()
Get the hostname or IP address of the server.
getSoftwareLink()
Returns a wikitext style link to the DB's website (e.g.
getLag()
Get the seconds of replication lag on this database server.
estimateRowCount( $tables, $var=' *', $conds='', $fname=__METHOD__, $options=[], $join_conds=[])
Estimate the number of rows in dataset.
getServerName()
Get the readable name for the server.
getServerInfo()
Get a human-readable string describing the current software version.
const UNION_ALL
Parameter to unionQueries() for UNION ALL.
getDomainID()
Return the currently selected domain ID.
databasesAreIndependent()
Returns true if DBs are assumed to be on potentially different servers.
expr(string $field, string $op, $value)
See Expression::__construct()
newUnionQueryBuilder()
Create an empty UnionQueryBuilder which can be used to run queries against this connection.
andExpr(array $conds)
See Expression::__construct()
const UNION_DISTINCT
Parameter to unionQueries() for UNION DISTINCT.
orExpr(array $conds)
See Expression::__construct()
__toString()
Get a debugging string that mentions the database type, the ID of this instance, and the ID of any un...
Interface for query language.

Follow Lee on X/Twitter - Father, Husband, Serial builder creating AI, crypto, games & web tools. We are friends :) AI Will Come To Life!

Check out: eBank.nz (Art Generator) | Netwrck.com (AI Tools) | Text-Generator.io (AI API) | BitBank.nz (Crypto AI) | ReadingTime (Kids Reading) | RewordGame | BigMultiplayerChess | WebFiddle | How.nz | Helix AI Assistant