Source of file SQL.php

Size: 4,055 Bytes - Last Modified: 2018-01-26T16:49:53+00:00

src/Drivers/Mysql/SQL.php

12345678910111213141516171819202122232425262728293031323334
Covered by 19 test(s):
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testQueryExplain
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testGetLimit
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testGetLimitSkip
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testGetWhere
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testSelectWhereGet
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testSelectGet
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testSelectFromLimitGet
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testSelectWhereGet2
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testGroup
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testOrGroup
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testOrNotGroup
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testAndNotGroupStart
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testNotGroupStart
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testGroupCamelCase
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testOrderBy
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testOrderByRandom
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testGroupBy
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testOrWhere
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testCountAllResults2
3536
Covered by 2 test(s):
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testGetLimit
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testSelectFromLimitGet
373839
Covered by 17 test(s):
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testQueryExplain
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testGetLimitSkip
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testGetWhere
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testSelectWhereGet
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testSelectGet
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testSelectWhereGet2
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testGroup
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testOrGroup
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testOrNotGroup
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testAndNotGroupStart
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testNotGroupStart
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testGroupCamelCase
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testOrderBy
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testOrderByRandom
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testGroupBy
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testOrWhere
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testCountAllResults2
4041424344454647484950
Covered by 1 test(s):
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testQueryExplain
51525354555657585960
Covered by 1 test(s):
  • Query\Tests\Drivers\MySQL\MySQLQueryBuilderTest::testOrderByRandom
6162636465666768697071
Covered by 1 test(s):
  • Query\Tests\Drivers\MySQL\MySQLDriverTest::testBackup
7273747576777879808182838485868788899091
Covered by 3 test(s):
  • Query\Tests\Drivers\MySQL\MySQLDriverTest::testCreateTable
  • Query\Tests\Drivers\MySQL\MySQLDriverTest::testGetTables
  • Query\Tests\Drivers\MySQL\MySQLDriverTest::testBackupData
9293949596979899100101102
Covered by 1 test(s):
  • Query\Tests\Drivers\MySQL\MySQLDriverTest::testGetSystemTables
103104105106107108109110111112113114
Covered by 1 test(s):
  • Query\Tests\Drivers\MySQL\MySQLDriverTest::testGetViews
115116117118119120121122123124
Covered by 1 test(s):
  • Query\Tests\Drivers\MySQL\MySQLDriverTest::testGetTriggers
125126127128129130131132133134
Covered by 1 test(s):
  • Query\Tests\Drivers\MySQL\MySQLDriverTest::testGetFunctions
135136137138139140141142143144
Covered by 1 test(s):
  • Query\Tests\Drivers\MySQL\MySQLDriverTest::testGetProcedures
145146147148149150151152153154
Covered by 1 test(s):
  • Query\Tests\Drivers\MySQL\MySQLDriverTest::testGetSequences
155156157158159160161162163164
Covered by 1 test(s):
  • Query\Tests\Drivers\MySQL\MySQLDriverTest::testGetTypes
165166167168169170171172173174175
Covered by 1 test(s):
  • Query\Tests\Drivers\MySQL\MySQLDriverTest::testGetColumns
176177178179180181182183184185186187188189190191192193194195196197198199200
Covered by 1 test(s):
  • Query\Tests\Drivers\MySQL\MySQLDriverTest::testGetFKs
201202203204205206207208209210211212
Covered by 1 test(s):
  • Query\Tests\Drivers\MySQL\MySQLDriverTest::testGetIndexes
213214
<?php declare(strict_types=1);
/**
 * Query
 *
 * SQL Query Builder / Database Abstraction Layer
 *
 * PHP version 7.1
 *
 * @package     Query
 * @author      Timothy J. Warren <tim@timshomepage.net>
 * @copyright   2012 - 2018 Timothy J. Warren
 * @license     http://www.opensource.org/licenses/mit-license.html  MIT License
 * @link        https://git.timshomepage.net/aviat4ion/Query
 */
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, $offset=FALSE): 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 <<<SQL
			SHOW DATABASES WHERE `Database` NOT IN ('information_schema','mysql')
SQL;

	}

	/**
	 * Returns sql to list tables
	 *
	 * @param string $database
	 * @return string
	 */
	public function tableList($database=''): string
	{
		// @codeCoverageIgnoreStart
		if ( ! empty($database))
		{
			return "SHOW TABLES FROM `{$database}`";
		}
		// @codeCoverageIgnoreEnd

		return 'SHOW TABLES';
	}

	/**
	 * Overridden in MySQL class
	 *
	 * @return string
	 */
	public function systemTableList(): string
	{
		return <<<SQL
			SELECT `TABLE_NAME` FROM `information_schema`.`TABLES`
			WHERE `TABLE_SCHEMA`='information_schema'
SQL;
	}

	/**
	 * Returns sql to list views
	 *
	 * @return string
	 */
	public function viewList(): string
	{
		return 'SELECT `table_name` FROM `information_schema`.`views`';
	}

	/**
	 * Returns sql to list triggers
	 *
	 * @return string
	 */
	public function triggerList(): string
	{
		return 'SHOW TRIGGERS';
	}

	/**
	 * Return sql to list functions
	 *
	 * @return string
	 */
	public function functionList(): string
	{
		return 'SHOW FUNCTION STATUS';
	}

	/**
	 * Return sql to list stored procedures
	 *
	 * @return string
	 */
	public function procedureList(): string
	{
		return 'SHOW PROCEDURE STATUS';
	}

	/**
	 * Return sql to list sequences
	 *
	 * @return string
	 */
	public function sequenceList(): ?string
	{
		return NULL;
	}

	/**
	 * SQL to show list of field types
	 *
	 * @return string
	 */
	public function typeList(): string
	{
		return 'SELECT DISTINCT `DATA_TYPE` FROM `information_schema`.`COLUMNS`';
	}

	/**
	 * SQL to show infromation about columns in a table
	 *
	 * @param string $table
	 * @return string
	 */
	public function columnList(string $table): string
	{
		return "SHOW FULL COLUMNS FROM {$table}";
	}

	/**
	 * Get the list of foreign keys for the current
	 * table
	 *
	 * @param string $table
	 * @return string
	 */
	public function fkList(string $table): string
	{
		return <<<SQL
			SELECT DISTINCT 
				`kcu`.`COLUMN_NAME` as `child_column`,
				`kcu`.`REFERENCED_TABLE_NAME` as `parent_table`,
				`kcu`.`REFERENCED_COLUMN_NAME` as `parent_column`,
				`rc`.`UPDATE_RULE` AS `update`,
				`rc`.`DELETE_RULE` AS `delete`
			FROM `INFORMATION_SCHEMA`.`TABLE_CONSTRAINTS` `tc`
			INNER JOIN `INFORMATION_SCHEMA`.`KEY_COLUMN_USAGE` `kcu`
				ON `kcu`.`CONSTRAINT_NAME`=`tc`.`CONSTRAINT_NAME`
			INNER JOIN `INFORMATION_SCHEMA`.`REFERENTIAL_CONSTRAINTS` `rc`
				ON `rc`.`CONSTRAINT_NAME`=`tc`.`CONSTRAINT_NAME`
			WHERE `tc`.`CONSTRAINT_TYPE`='FOREIGN KEY'
			AND `tc`.`TABLE_NAME`='{$table}'
SQL;
	}

	/**
	 * Get the list of indexes for the current table
	 *
	 * @param string $table
	 * @return string
	 */
	public function indexList(string $table): string
	{
		return "SHOW INDEX IN {$table}";
	}
}