* @copyright 2012 - 2020 Timothy J. Warren * @license http://www.opensource.org/licenses/mit-license.html MIT License * @link https://git.timshomepage.net/aviat/Query * @version 3.0.0 */ namespace Query\Drivers\Mysql; use Query\Drivers\AbstractSQL; /** * MySQL specific SQL */ class SQL extends AbstractSQL { /** * Limit clause * * @param string $sql * @param int $limit * @param int|boolean $offset * @return string */ public function limit(string $sql, int $limit, ?int $offset=NULL): string { if ( ! is_numeric($offset)) { return $sql." LIMIT {$limit}"; } return $sql." LIMIT {$offset}, {$limit}"; } /** * Get the query plan for the sql query * * @param string $sql * @return string */ public function explain(string $sql): string { return "EXPLAIN EXTENDED {$sql}"; } /** * Random ordering keyword * * @return string */ public function random(): string { return ' RAND() DESC'; } /** * Returns sql to list other databases * * @return string */ public function dbList(): string { return <<