DatabaseInterface
class DatabaseInterface (View source)
Main interface for database interactions
Constants
QUERY_UNBUFFERED |
Do not read all rows immediately. |
GETVAR_SESSION |
Get session variable. |
GETVAR_GLOBAL |
Get global variable. |
FETCH_NUM |
|
FETCH_ASSOC |
|
Properties
static self|null | $instance | ||
Types | $types | ||
float | $lastQueryExecutionTime |
Methods
No description
No description
Send multiple SQL queries to the database server and execute the first one
Executes a query as controluser.
Executes a query as controluser.
returns array with table names for given db
returns array of all tables in given db or dbs
this function expects unquoted names:
RIGHT: my_database
WRONG: my_database
WRONG: my_database
if $tbl_is_group is true, $table is used as filter for table names
returns array with databases containing extended infos about them
Returns description of a $column in given table
Returns descriptions of columns in given table
Returns all column names in given table
Returns indexes of a table
returns value of given mysql server variable
Sets new value for a variable if it is different from the current value
No description
No description
Function called just after a connection to the MySQL database server has been established. It sets the connection collation, and determines the version of MySQL which is running.
Sets collation connection for user link
returns a single value from the given result or query, if the query or the result has more than one row or field the first field of the first row is returned
Returns only the first row from the result or null if result is empty.
returns all rows in the resultset in one array
No description
No description
Get supported SQL compatibility modes
returns warnings for last query
gets the current user with host
gets the current role with host. Role maybe multiple separated by comma Support start from MySQL 8.x / MariaDB 10.0.5
No description
No description
No description
No description
Get the current user and host
Get the current role and host.
Returns value for lower_case_table_names variable
selects given database
Prepare next result from multi_query
Returns a string representing the type of connection used
returns a string that represents the client library version
Returns last error message or an empty string if no errors occurred.
returns last inserted auto_increment id for given $link
returns the number of rows affected by last query
Returns properly quoted string for use in MySQL queries.
Returns properly escaped string for use in MySQL LIKE clauses.
Checks if this database server is running on Amazon RDS.
Gets SQL for killing a process.
returns collation of given db
returns default server collation from show variables
Server version as number
Server version
Server version comment
Whether connection is MySQL
Whether connection is MariaDB
Whether connection is PerconaDB
Set version
No description
No description
Details
static DatabaseInterface
getInstance(Config|null $config = null)
deprecated
deprecated
No description
static DatabaseInterface
getInstanceForTest(DbiExtension $extension, Config|null $config = null)
No description
ResultInterface
query(string $query, ConnectionType $connectionType = ConnectionType::User, bool $unbuffered = false, bool $cacheAffectedRows = true)
No description
Cache
getCache()
No description
ResultInterface|false
tryQuery(string $query, ConnectionType $connectionType = ConnectionType::User, bool $unbuffered = false, bool $cacheAffectedRows = true)
No description
bool
tryMultiQuery(string $multiQuery = '', ConnectionType $connectionType = ConnectionType::User)
Send multiple SQL queries to the database server and execute the first one
ResultInterface
queryAsControlUser(string $sql)
Executes a query as controluser.
The result is always buffered and never cached
ResultInterface|false
tryQueryAsControlUser(string $sql)
Executes a query as controluser.
The result is always buffered and never cached
array
getTables(string $database, ConnectionType $connectionType = ConnectionType::User)
returns array with table names for given db
array
getTablesFull(string $database, string|array $table = '', bool $tableIsGroup = false, int $limitOffset = 0, bool|int $limitCount = false, string $sortBy = 'Name', string $sortOrder = 'ASC', string|null $tableType = null, ConnectionType $connectionType = ConnectionType::User)
returns array of all tables in given db or dbs
this function expects unquoted names:
RIGHT: my_database
WRONG: my_database
WRONG: my_database
if $tbl_is_group is true, $table is used as filter for table names
$dbi->getTablesFull('my_database');
$dbi->getTablesFull('my_database', 'my_table'));
$dbi->getTablesFull('my_database', 'my_tables_', true));
array
getDatabasesFull(string|null $database = null, bool $forceStats = false, ConnectionType $connectionType = ConnectionType::User, string $sortBy = 'SCHEMA_NAME', string $sortOrder = 'ASC', int $limitOffset = 0, bool|int $limitCount = false)
returns array with databases containing extended infos about them
Column|null
getColumn(string $database, string $table, string $column, bool $full = false, ConnectionType $connectionType = ConnectionType::User)
Returns description of a $column in given table
array
getColumns(string $database, string $table, bool $full = false, ConnectionType $connectionType = ConnectionType::User)
Returns descriptions of columns in given table
array
getColumnNames(string $database, string $table, ConnectionType $connectionType = ConnectionType::User)
Returns all column names in given table
array
getTableIndexes(string $database, string $table, ConnectionType $connectionType = ConnectionType::User)
Returns indexes of a table
false|string|null
getVariable(string $var, int $type = self::GETVAR_SESSION, ConnectionType $connectionType = ConnectionType::User)
returns value of given mysql server variable
void
setVariable(string $var, string $value, ConnectionType $connectionType = ConnectionType::User)
Sets new value for a variable if it is different from the current value
string
getDefaultCharset()
No description
string
getDefaultCollation()
No description
void
postConnect(Server $currentServer)
Function called just after a connection to the MySQL database server has been established. It sets the connection collation, and determines the version of MySQL which is running.
void
setCollation(string $collation)
Sets collation connection for user link
string|false|null
fetchValue(string $query, int|string $field = 0, ConnectionType $connectionType = ConnectionType::User)
returns a single value from the given result or query, if the query or the result has more than one row or field the first field of the first row is returned
$sql = 'SELECT `name` FROM `user` WHERE `id` = 123';
$user_name = $dbi->fetchValue($sql);
// produces
// $user_name = 'John Doe'
array
fetchSingleRow(string $query, string $type = self::FETCH_ASSOC, ConnectionType $connectionType = ConnectionType::User)
Returns only the first row from the result or null if result is empty.
$sql = 'SELECT * FROM `user` WHERE `id` = 123';
$user = $dbi->fetchSingleRow($sql);
// produces
// $user = array('id' => 123, 'name' => 'John Doe')
array
fetchResult(string $query, string|int|array $key, string|int|null $value = null, ConnectionType $connectionType = ConnectionType::User)
returns all rows in the resultset in one array
$sql = 'SELECT * FROM `user`';
$users = $dbi->fetchResult($sql);
// produces
// $users[] = array('id' => 123, 'name' => 'John Doe')
$sql = 'SELECT `id`, `name` FROM `user`';
$users = $dbi->fetchResult($sql, 'id');
// produces
// $users['123'] = array('id' => 123, 'name' => 'John Doe')
$sql = 'SELECT `id`, `name` FROM `user`';
$users = $dbi->fetchResult($sql, 0);
// produces
// $users['123'] = array(0 => 123, 1 => 'John Doe')
$sql = 'SELECT `id`, `name` FROM `user`';
$users = $dbi->fetchResult($sql, 'id', 'name');
// or
$users = $dbi->fetchResult($sql, 0, 1);
// produces
// $users['123'] = 'John Doe'
$sql = 'SELECT `name` FROM `user`';
$users = $dbi->fetchResult($sql);
// produces
// $users[] = 'John Doe'
$sql = 'SELECT `group`, `name` FROM `user`'
$users = $dbi->fetchResult($sql, array('group', null), 'name');
// produces
// $users['admin'][] = 'John Doe'
$sql = 'SELECT `group`, `name` FROM `user`'
$users = $dbi->fetchResult($sql, array('group', 'name'), 'id');
// produces
// $users['admin']['John Doe'] = '123'
array
fetchResultSimple(string $query, ConnectionType $connectionType = ConnectionType::User)
No description
array
fetchSingleColumn(string $query, ConnectionType $connectionType = ConnectionType::User)
No description
array
getCompatibilities()
Get supported SQL compatibility modes
array
getWarnings(ConnectionType $connectionType = ConnectionType::User)
returns warnings for last query
string
getCurrentUser()
gets the current user with host
array
getCurrentRoles()
gets the current role with host. Role maybe multiple separated by comma Support start from MySQL 8.x / MariaDB 10.0.5
bool
isSuperUser()
No description
bool
isGrantUser()
No description
bool
isCreateUser()
No description
bool
isConnected()
No description
array
getCurrentUserAndHost()
Get the current user and host
array
getCurrentRolesAndHost()
Get the current role and host.
int
getLowerCaseNames()
Returns value for lower_case_table_names variable
Connection|null
connect(Server $currentServer, ConnectionType $connectionType, ConnectionType|null $target = null)
Connects to the database server.
bool
selectDb(DatabaseName $dbname, ConnectionType $connectionType = ConnectionType::User)
selects given database
ResultInterface|false
nextResult(ConnectionType $connectionType = ConnectionType::User)
Prepare next result from multi_query
string|bool
getHostInfo(ConnectionType $connectionType = ConnectionType::User)
Returns a string representing the type of connection used
string
getClientInfo()
returns a string that represents the client library version
string
getError(ConnectionType $connectionType = ConnectionType::User)
Returns last error message or an empty string if no errors occurred.
int
insertId(ConnectionType $connectionType = ConnectionType::User)
returns last inserted auto_increment id for given $link
int|string
affectedRows(ConnectionType $connectionType = ConnectionType::User, bool $getFromCache = true)
returns the number of rows affected by last query
array
getFieldsMeta(ResultInterface $result)
returns metainfo for fields in $result
string
quoteString(string $str, ConnectionType $connectionType = ConnectionType::User)
Returns properly quoted string for use in MySQL queries.
string
escapeMysqlWildcards(string $str)
Returns properly escaped string for use in MySQL LIKE clauses.
This method escapes only _, %, and /. It does not escape quotes or any other characters.
bool
isAmazonRds()
Checks if this database server is running on Amazon RDS.
string
getKillQuery(int $process)
Gets SQL for killing a process.
Table
getTable(string $dbName, string $tableName)
Get a table with database name and table name
string
getDbCollation(string $db)
returns collation of given db
string
getServerCollation()
returns default server collation from show variables
int
getVersion()
Server version as number
string
getVersionString()
Server version
string
getVersionComment()
Server version comment
bool
isMySql()
Whether connection is MySQL
bool
isMariaDB()
Whether connection is MariaDB
bool
isPercona()
Whether connection is PerconaDB
void
setVersion(array $version)
Set version
ResultInterface|null
executeQuery(string $query, array $params, ConnectionType $connectionType = ConnectionType::User)
No description
ListDatabase
getDatabaseList()
No description