UnknownSec Bypass
403
:
/
usr
/
share
/
php
/
PhpMyAdmin
/
SqlParser
/
Statements
/ [
drwxr-xr-x
]
Menu
Upload
Mass depes
Mass delete
Terminal
Info server
About
name :
SelectStatement.php
<?php /** * `SELECT` statement. */ namespace PhpMyAdmin\SqlParser\Statements; use PhpMyAdmin\SqlParser\Components\ArrayObj; use PhpMyAdmin\SqlParser\Components\Condition; use PhpMyAdmin\SqlParser\Components\Expression; use PhpMyAdmin\SqlParser\Components\FunctionCall; use PhpMyAdmin\SqlParser\Components\IndexHint; use PhpMyAdmin\SqlParser\Components\IntoKeyword; use PhpMyAdmin\SqlParser\Components\JoinKeyword; use PhpMyAdmin\SqlParser\Components\Limit; use PhpMyAdmin\SqlParser\Components\OptionsArray; use PhpMyAdmin\SqlParser\Components\OrderKeyword; use PhpMyAdmin\SqlParser\Statement; /** * `SELECT` statement. * * SELECT * [ALL | DISTINCT | DISTINCTROW ] * [HIGH_PRIORITY] * [MAX_STATEMENT_TIME = N] * [STRAIGHT_JOIN] * [SQL_SMALL_RESULT] [SQL_BIG_RESULT] [SQL_BUFFER_RESULT] * [SQL_CACHE | SQL_NO_CACHE] [SQL_CALC_FOUND_ROWS] * select_expr [, select_expr ...] * [FROM table_references * [PARTITION partition_list] * [WHERE where_condition] * [GROUP BY {col_name | expr | position} * [ASC | DESC), ... [WITH ROLLUP]] * [HAVING where_condition] * [ORDER BY {col_name | expr | position} * [ASC | DESC), ...] * [LIMIT {[offset,] row_count | row_count OFFSET offset}] * [PROCEDURE procedure_name(argument_list)] * [INTO OUTFILE 'file_name' * [CHARACTER SET charset_name] * export_options * | INTO DUMPFILE 'file_name' * | INTO var_name [, var_name]] * [FOR UPDATE | LOCK IN SHARE MODE]] * * @category Statements * * @license https://www.gnu.org/licenses/gpl-2.0.txt GPL-2.0+ */ class SelectStatement extends Statement { /** * Options for `SELECT` statements and their slot ID. * * @var array */ public static $OPTIONS = array( 'ALL' => 1, 'DISTINCT' => 1, 'DISTINCTROW' => 1, 'HIGH_PRIORITY' => 2, 'MAX_STATEMENT_TIME' => array( 3, 'var=', ), 'STRAIGHT_JOIN' => 4, 'SQL_SMALL_RESULT' => 5, 'SQL_BIG_RESULT' => 6, 'SQL_BUFFER_RESULT' => 7, 'SQL_CACHE' => 8, 'SQL_NO_CACHE' => 8, 'SQL_CALC_FOUND_ROWS' => 9 ); public static $END_OPTIONS = array( 'FOR UPDATE' => 1, 'LOCK IN SHARE MODE' => 1 ); /** * The clauses of this statement, in order. * * @see Statement::$CLAUSES * * @var array */ public static $CLAUSES = array( 'SELECT' => array( 'SELECT', 2, ), // Used for options. '_OPTIONS' => array( '_OPTIONS', 1, ), // Used for selected expressions. '_SELECT' => array( 'SELECT', 1, ), 'INTO' => array( 'INTO', 3, ), 'FROM' => array( 'FROM', 3, ), 'FORCE' => array( 'FORCE', 1, ), 'USE' => array( 'USE', 1, ), 'IGNORE' => array( 'IGNORE', 3, ), 'PARTITION' => array( 'PARTITION', 3, ), 'JOIN' => array( 'JOIN', 1, ), 'FULL JOIN' => array( 'FULL JOIN', 1, ), 'INNER JOIN' => array( 'INNER JOIN', 1, ), 'LEFT JOIN' => array( 'LEFT JOIN', 1, ), 'LEFT OUTER JOIN' => array( 'LEFT OUTER JOIN', 1, ), 'RIGHT JOIN' => array( 'RIGHT JOIN', 1, ), 'RIGHT OUTER JOIN' => array( 'RIGHT OUTER JOIN', 1, ), 'NATURAL JOIN' => array( 'NATURAL JOIN', 1, ), 'NATURAL LEFT JOIN' => array( 'NATURAL LEFT JOIN', 1, ), 'NATURAL RIGHT JOIN' => array( 'NATURAL RIGHT JOIN', 1, ), 'NATURAL LEFT OUTER JOIN' => array( 'NATURAL LEFT OUTER JOIN', 1, ), 'NATURAL RIGHT OUTER JOIN' => array( 'NATURAL RIGHT JOIN', 1, ), 'WHERE' => array( 'WHERE', 3, ), 'GROUP BY' => array( 'GROUP BY', 3, ), 'HAVING' => array( 'HAVING', 3, ), 'ORDER BY' => array( 'ORDER BY', 3, ), 'LIMIT' => array( 'LIMIT', 3, ), 'PROCEDURE' => array( 'PROCEDURE', 3, ), 'UNION' => array( 'UNION', 1, ), 'EXCEPT' => array( 'EXCEPT', 1, ), 'INTERSECT' => array( 'INTERSECT', 1, ), '_END_OPTIONS' => array( '_END_OPTIONS', 1, ), // These are available only when `UNION` is present. // 'ORDER BY' => array('ORDER BY', 3), // 'LIMIT' => array('LIMIT', 3) ); /** * Expressions that are being selected by this statement. * * @var Expression[] */ public $expr = array(); /** * Tables used as sources for this statement. * * @var Expression[] */ public $from = array(); /** * Index hints * * @var IndexHint[] */ public $index_hints; /** * Partitions used as source for this statement. * * @var ArrayObj */ public $partition; /** * Conditions used for filtering each row of the result set. * * @var Condition[] */ public $where; /** * Conditions used for grouping the result set. * * @var OrderKeyword[] */ public $group; /** * Conditions used for filtering the result set. * * @var Condition[] */ public $having; /** * Specifies the order of the rows in the result set. * * @var OrderKeyword[] */ public $order; /** * Conditions used for limiting the size of the result set. * * @var Limit */ public $limit; /** * Procedure that should process the data in the result set. * * @var FunctionCall */ public $procedure; /** * Destination of this result set. * * @var IntoKeyword */ public $into; /** * Joins. * * @var JoinKeyword[] */ public $join; /** * Unions. * * @var SelectStatement[] */ public $union = array(); /** * The end options of this query. * * @var OptionsArray * * @see static::$END_OPTIONS */ public $end_options; /** * Gets the clauses of this statement. * * @return array */ public function getClauses() { // This is a cheap fix for `SELECT` statements that contain `UNION`. // The `ORDER BY` and `LIMIT` clauses should be at the end of the // statement. if (! empty($this->union)) { $clauses = static::$CLAUSES; unset($clauses['ORDER BY'], $clauses['LIMIT']); $clauses['ORDER BY'] = array( 'ORDER BY', 3 ); $clauses['LIMIT'] = array( 'LIMIT', 3 ); return $clauses; } return static::$CLAUSES; } }
Copyright © 2025 - UnknownSec