2016-10-05 22:08:43 -04:00
|
|
|
<?php
|
2017-11-16 20:23:18 -05:00
|
|
|
/** @license MIT
|
|
|
|
* Copyright 2017 J. King, Dustin Wilson et al.
|
|
|
|
* See LICENSE and AUTHORS files for details */
|
|
|
|
|
2016-10-05 22:08:43 -04:00
|
|
|
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-05-07 18:27:16 -04:00
|
|
|
const TR_PEND = 0;
|
|
|
|
const TR_COMMIT = 1;
|
|
|
|
const TR_ROLLBACK = 2;
|
|
|
|
const TR_PEND_COMMIT = -1;
|
|
|
|
const TR_PEND_ROLLBACK = -2;
|
2018-10-26 14:58:04 -04:00
|
|
|
|
2017-12-18 18:29:32 -05:00
|
|
|
public static function create(): Driver;
|
2017-02-16 14:29:42 -06:00
|
|
|
// returns a human-friendly name for the driver (for display in installer, for example)
|
2017-08-29 10:50:31 -04:00
|
|
|
public static function driverName(): string;
|
2017-02-16 14:29:42 -06:00
|
|
|
// returns the version of the scheme of the opened database; if uninitialized should return 0
|
2017-08-29 10:50:31 -04:00
|
|
|
public function schemaVersion(): int;
|
2017-12-18 18:29:32 -05:00
|
|
|
// returns the schema set to be used for database set-up
|
|
|
|
public static function schemaID(): string;
|
2017-05-06 12:02:27 -04:00
|
|
|
// return a Transaction object
|
2017-08-29 10:50:31 -04:00
|
|
|
public function begin(bool $lock = false): Transaction;
|
2017-05-06 12:02:27 -04:00
|
|
|
// manually begin a real or synthetic transactions, with real or synthetic nesting
|
2017-08-29 10:50:31 -04:00
|
|
|
public function savepointCreate(): int;
|
2017-05-06 12:02:27 -04:00
|
|
|
// manually commit either the latest or all pending nested transactions
|
2017-08-29 10:50:31 -04:00
|
|
|
public function savepointRelease(int $index = null): bool;
|
2017-05-06 12:02:27 -04:00
|
|
|
// manually rollback either the latest or all pending nested transactions
|
2017-08-29 10:50:31 -04:00
|
|
|
public function savepointUndo(int $index = null): bool;
|
2017-02-16 14:29:42 -06:00
|
|
|
// attempt to perform an in-place upgrade of the database schema; this may be a no-op which always throws an exception
|
2017-08-29 10:50:31 -04:00
|
|
|
public 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
|
2017-08-29 10:50:31 -04:00
|
|
|
public function exec(string $query): bool;
|
2017-02-16 14:29:42 -06:00
|
|
|
// perform a single unsanitized query and return a result set
|
2017-08-29 10:50:31 -04:00
|
|
|
public function query(string $query): Result;
|
2017-02-16 14:29:42 -06:00
|
|
|
// ready a prepared statement for later execution
|
2017-08-29 10:50:31 -04:00
|
|
|
public function prepare(string $query, ...$paramType): Statement;
|
|
|
|
public function prepareArray(string $query, array $paramTypes): Statement;
|
2017-11-29 18:14:59 -05:00
|
|
|
// report whether the database character set is correct/acceptable
|
|
|
|
public function charsetAcceptable(): bool;
|
2018-12-04 20:41:21 -05:00
|
|
|
// return an implementation-dependent form of a reference SQL function or operator
|
|
|
|
public function sqlToken(string $token): string;
|
2017-08-29 10:50:31 -04:00
|
|
|
}
|