%PDF-1.5 %���� ºaâÚÎΞ-ÌE1ÍØÄ÷{òò2ÿ ÛÖ^ÔÀá TÎ{¦?§®¥kuµùÕ5sLOšuY
Server IP : 49.231.201.246 / Your IP : 216.73.216.149 Web Server : Apache/2.4.18 (Ubuntu) System : Linux 246 4.4.0-210-generic #242-Ubuntu SMP Fri Apr 16 09:57:56 UTC 2021 x86_64 User : root ( 0) PHP Version : 7.0.33-0ubuntu0.16.04.16 Disable Function : exec,passthru,shell_exec,system,proc_open,popen,pcntl_exec MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : ON Directory : /proc/thread-self/root/proc/self/root/usr/share/phpmyadmin/libraries/sql-parser/src/Utils/ |
Upload File : |
<?php /** * Table utilities. * * @package SqlParser * @subpackage Utils */ namespace SqlParser\Utils; use SqlParser\Statements\CreateStatement; /** * Table utilities. * * @category Statement * @package SqlParser * @subpackage Utils * @author Dan Ungureanu <udan1107@gmail.com> * @license http://opensource.org/licenses/GPL-2.0 GNU Public License */ class Table { /** * Gets the foreign keys of the table. * * @param CreateStatement $statement The statement to be processed. * * @return array */ public static function getForeignKeys($statement) { if ((empty($statement->fields)) || (!is_array($statement->fields)) || (!$statement->options->has('TABLE')) ) { return array(); } $ret = array(); foreach ($statement->fields as $field) { if ((empty($field->key)) || ($field->key->type !== 'FOREIGN KEY')) { continue; } $columns = array(); foreach ($field->key->columns as $column) { $columns[] = $column['name']; } $tmp = array( 'constraint' => $field->name, 'index_list' => $columns, ); if (!empty($field->references)) { $tmp['ref_db_name'] = $field->references->table->database; $tmp['ref_table_name'] = $field->references->table->table; $tmp['ref_index_list'] = $field->references->columns; if (($opt = $field->references->options->has('ON UPDATE'))) { $tmp['on_update'] = str_replace(' ', '_', $opt); } if (($opt = $field->references->options->has('ON DELETE'))) { $tmp['on_delete'] = str_replace(' ', '_', $opt); } // if (($opt = $field->references->options->has('MATCH'))) { // $tmp['match'] = str_replace(' ', '_', $opt); // } } $ret[] = $tmp; } return $ret; } /** * Gets fields of the table. * * @param CreateStatement $statement The statement to be processed. * * @return array */ public static function getFields($statement) { if ((empty($statement->fields)) || (!is_array($statement->fields)) || (!$statement->options->has('TABLE')) ) { return array(); } $ret = array(); foreach ($statement->fields as $field) { // Skipping keys. if (empty($field->type)) { continue; } $ret[$field->name] = array( 'type' => $field->type->name, 'timestamp_not_null' => false, ); if ($field->options) { if ($field->type->name === 'TIMESTAMP') { if ($field->options->has('NOT NULL')) { $ret[$field->name]['timestamp_not_null'] = true; } } if (($option = $field->options->has('DEFAULT'))) { $ret[$field->name]['default_value'] = $option; if ($option === 'CURRENT_TIMESTAMP') { $ret[$field->name]['default_current_timestamp'] = true; } } if (($option = $field->options->has('ON UPDATE'))) { if ($option === 'CURRENT_TIMESTAMP') { $ret[$field->name]['on_update_current_timestamp'] = true; } } if (($option = $field->options->has('AS'))) { $ret[$field->name]['generated'] = true; $ret[$field->name]['expr'] = $option; } } } return $ret; } }