2016-10-05 22:08:43 -04:00
|
|
|
<?php
|
|
|
|
declare(strict_types=1);
|
2017-03-27 23:12:12 -05:00
|
|
|
namespace JKingWeb\Arsse\Db;
|
2016-10-05 22:08:43 -04:00
|
|
|
|
2017-03-02 09:04:04 -05:00
|
|
|
interface Driver {
|
2017-03-28 18:50:00 -04:00
|
|
|
function __construct(bool $install = false);
|
2017-02-16 14:29:42 -06:00
|
|
|
// returns a human-friendly name for the driver (for display in installer, for example)
|
|
|
|
static function driverName(): string;
|
|
|
|
// returns the version of the scheme of the opened database; if uninitialized should return 0
|
|
|
|
function schemaVersion(): int;
|
|
|
|
// begin a real or synthetic transactions, with real or synthetic nesting
|
|
|
|
function begin(): bool;
|
|
|
|
// commit either the latest or all pending nested transactions; use of this method should assume a partial commit is a no-op
|
|
|
|
function commit(bool $all = false): bool;
|
|
|
|
// rollback either the latest or all pending nested transactions; use of this method should assume a partial rollback will not work
|
|
|
|
function rollback(bool $all = false): bool;
|
|
|
|
// attempt to advise other processes that they should not attempt to access the database; used during live upgrades
|
|
|
|
function lock(): bool;
|
|
|
|
function unlock(): bool;
|
|
|
|
function isLocked(): bool;
|
|
|
|
// attempt to perform an in-place upgrade of the database schema; this may be a no-op which always throws an exception
|
2017-03-02 22:43:59 -05:00
|
|
|
function schemaUpdate(int $to): bool;
|
2017-02-16 14:29:42 -06:00
|
|
|
// execute one or more unsanitized SQL queries and return an indication of success
|
|
|
|
function exec(string $query): bool;
|
|
|
|
// perform a single unsanitized query and return a result set
|
|
|
|
function query(string $query): Result;
|
|
|
|
// ready a prepared statement for later execution
|
2017-04-06 11:02:47 -04:00
|
|
|
function prepare(string $query, ...$paramType): Statement;
|
2016-10-05 22:08:43 -04:00
|
|
|
}
|