home *** CD-ROM | disk | FTP | other *** search
/ Enter 2004 June / ENTER.ISO / files / xampp-win32-1.4.5-installer.exe / xampp / sqlparser.data.php < prev    next >
Encoding:
PHP Script  |  2004-01-08  |  8.0 KB  |  508 lines

  1. <?php
  2. /* $Id: sqlparser.data.php,v 2.5 2004/01/09 14:16:45 lem9 Exp $ */
  3. // vim: expandtab sw=4 ts=4 sts=4:
  4.  
  5.  
  6. /** SQL Parser Matching Data
  7.  *
  8.  * Copyright 2002 Robin Johnson <robbat2@users.sourceforge.net>
  9.  * http://www.orbis-terrarum.net/?l=people.robbat2
  10.  *
  11.  * This data is used by the SQL Parser to recognize keywords
  12.  *
  13.  * It has been extracted from the lex.h file in the MySQL BK tree
  14.  * (around 4.0.2) as well as the MySQL documentation.
  15.  */
  16.  
  17. $PMA_SQPdata_function_name = array (
  18.     'ABS',
  19.     'ACOS',
  20.     'ADDDATE',
  21.     'AES_ENCRYPT',
  22.     'AES_DECRYPT',
  23.     'ASCII',
  24.     'ASIN',
  25.     'ATAN',
  26.     'ATAN2',
  27.     'AVG',
  28.     'BENCHMARK',
  29.     'BIN',
  30.     'BIT_AND',
  31.     'BIT_COUNT',
  32.     'BIT_LENGTH',
  33.     'BIT_OR',
  34.     'CAST',
  35.     'CEIL',
  36.     'CEILING',
  37.     'CHAR_LENGTH',
  38.     'CHARACTER_LENGTH',
  39.     'COALESCE',
  40.     'CONCAT',
  41.     'CONCAT_WS',
  42.     'CONNECTION_ID',
  43.     'CONV',
  44.     'CONVERT',
  45.     'COS',
  46.     'COT',
  47.     'COUNT',
  48.     'CURDATE',
  49.     'CURRENT_DATE',
  50.     'CURRENT_TIME',
  51.     'CURRENT_TIMESTAMP',
  52.     'CURRENT_USER',
  53.     'CURTIME',
  54.     'DATABASE',
  55.     'DATE_ADD',
  56.     'DATE_FORMAT',
  57.     'DATE_SUB',
  58.     'DAYNAME',
  59.     'DAYOFMONTH',
  60.     'DAYOFWEEK',
  61.     'DAYOFYEAR',
  62.     'DECODE',
  63.     'DEGREES',
  64.     'DES_ENCRYPT',
  65.     'DES_DECRYPT',
  66.     'ELT',
  67.     'ENCODE',
  68.     'ENCRYPT',
  69.     'EXP',
  70.     'EXPORT_SET',
  71.     'EXTRACT',
  72.     'FIELD',
  73.     'FIND_IN_SET',
  74.     'FLOOR',
  75.     'FORMAT',
  76.     'FOUND_ROWS',
  77.     'FROM_DAYS',
  78.     'FROM_UNIXTIME',
  79.     'GET_LOCK',
  80.     'GREATEST',
  81.     'GROUP_UNIQUE_USERS',
  82.     'HEX',
  83.     'IFNULL',
  84.     'INET_ATON',
  85.     'INET_NTOA',
  86.     'INSTR',
  87.     'INTERVAL',
  88.     'IS_FREE_LOCK',
  89.     'ISNULL',
  90.     'LAST_INSERT_ID',
  91.     'LCASE',
  92.     'LEAST',
  93.     'LEFT',
  94.     'LENGTH',
  95.     'LN',
  96.     'LOAD_FILE',
  97.     'LOCATE',
  98.     'LOG',
  99.     'LOG2',
  100.     'LOG10',
  101.     'LOWER',
  102.     'LPAD',
  103.     'LTRIM',
  104.     'MAKE_SET',
  105.     'MASTER_POS_WAIT',
  106.     'MAX',
  107.     'MD5',
  108.     'MID',
  109.     'MIN',
  110.     'MOD',
  111.     'MONTH',
  112.     'MONTHNAME',
  113.     'NOW',
  114.     'NULLIF',
  115.     'OCT',
  116.     'OCTET_LENGTH',
  117.     'ORD',
  118.     'PASSWORD',
  119.     'PERIOD_ADD',
  120.     'PERIOD_DIFF',
  121.     'PI',
  122.     'POSITION',
  123.     'POW',
  124.     'POWER',
  125.     'QUARTER',
  126.     'QUOTE',
  127.     'RADIANS',
  128.     'RAND',
  129.     'RELEASE_LOCK',
  130.     'REPEAT',
  131.     'REVERSE',
  132.     'RIGHT',
  133.     'ROUND',
  134.     'RPAD',
  135.     'RTRIM',
  136.     'SEC_TO_TIME',
  137.     'SESSION_USER',
  138.     'SHA',
  139.     'SHA1',
  140.     'SIGN',
  141.     'SIN',
  142.     'SOUNDEX',
  143.     'SPACE',
  144.     'SQRT',
  145.     'STD',
  146.     'STDDEV',
  147.     'STRCMP',
  148.     'SUBDATE',
  149.     'SUBSTRING',
  150.     'SUBSTRING_INDEX',
  151.     'SUM',
  152.     'SYSDATE',
  153.     'SYSTEM_USER',
  154.     'TAN',
  155.     'TIME_FORMAT',
  156.     'TIME_TO_SEC',
  157.     'TO_DAYS',
  158.     'TRIM',
  159.     'UCASE',
  160.     'UNIQUE_USERS',
  161.     'UNIX_TIMESTAMP',
  162.     'UPPER',
  163.     'USER',
  164.     'VERSION',
  165.     'WEEK',
  166.     'WEEKDAY',
  167.     'YEAR',
  168.     'YEARWEEK'
  169. );
  170. //$PMA_SQPdata_function_name_cnt = count($PMA_SQPdata_function_name);
  171. $PMA_SQPdata_function_name_cnt = 151;
  172.  
  173. $PMA_SQPdata_column_attrib = array (
  174.     'AUTO_INCREMENT',
  175.     'BDB',
  176.     'BERKELEYDB',
  177.     'BINARY',
  178.     'DEFAULT',
  179.     'INNOBASE',
  180.     'INNODB',
  181.     'ISAM',
  182.     'MRG_MYISAM',
  183.     'MYISAM',
  184.     'NATIONAL',
  185.     'PRECISION',
  186.     'UNSIGNED',
  187.     'VARYING',
  188.     'ZEROFILL'
  189. );
  190. //$PMA_SQPdata_column_attrib_cnt = count($PMA_SQPdata_column_attrib);
  191. $PMA_SQPdata_column_attrib_cnt = 15;
  192.  
  193. $PMA_SQPdata_reserved_word = array (
  194.     'ACTION',
  195.     'ADD',
  196.     'AFTER',
  197.     'AGAINST',
  198.     'AGGREGATE',
  199.     'ALL',
  200.     'ALTER',
  201.     'ANALYSE',
  202.     'ANALYZE',
  203.     'AND',
  204.     'AS',
  205.     'ASC',
  206.     'AUTOCOMMIT',
  207.     'AUTO_INCREMENT',
  208.     'AVG_ROW_LENGTH',
  209.     'BACKUP',
  210.     'BEGIN',
  211.     'BETWEEN',
  212.     'BINLOG',
  213.     'BOTH',
  214.     'BY',
  215.     'CASCADE',
  216.     'CASE',
  217.     'CHANGE',
  218.     'CHANGED',
  219.     'CHARSET',
  220.     'CHECK',
  221.     'CHECKSUM',
  222.     'CLIENT',
  223.     'COLLATE',
  224.     'COLLATION',
  225.     'COLUMN',
  226.     'COLUMNS',
  227.     'COMMENT',
  228.     'COMMIT',
  229.     'COMMITTED',
  230.     'COMPRESSED',
  231.     'CONCURRENT',
  232.     'CONSTRAINT',
  233.     'CREATE',
  234.     'CROSS',
  235.     'DATA',
  236.     'DATABASE',
  237.     'DATABASES',
  238.     'DAY',
  239.     'DAY_HOUR',
  240.     'DAY_MINUTE',
  241.     'DAY_SECOND',
  242.     'DELAYED',
  243.     'DELAY_KEY_WRITE',
  244.     'DELETE',
  245.     'DESC',
  246.     'DESCRIBE',
  247.     'DISTINCT',
  248.     'DISTINCTROW',
  249.     'DIV',
  250.     'DO',
  251.     'DROP',
  252.     'DUMPFILE',
  253.     'DYNAMIC',
  254.     'ELSE',
  255.     'ENCLOSED',
  256.     'END',
  257.     'ESCAPE',
  258.     'ESCAPED',
  259.     'EVENTS',
  260.     'EXECUTE',
  261.     'EXISTS',
  262.     'EXPLAIN',
  263.     'EXTENDED',
  264.     'FAST',
  265.     'FIELDS',
  266.     'FILE',
  267.     'FIRST',
  268.     'FIXED',
  269.     'FLUSH',
  270.     'FOR',
  271.     'FORCE',
  272.     'FOREIGN',
  273.     'FROM',
  274.     'FULL',
  275.     'FULLTEXT',
  276.     'FUNCTION',
  277.     'GEMINI',
  278.     'GEMINI_SPIN_RETRIES',
  279.     'GLOBAL',
  280.     'GRANT',
  281.     'GRANTS',
  282.     'GROUP',
  283.     'HAVING',
  284.     'HEAP',
  285.     'HIGH_PRIORITY',
  286.     'HOSTS',
  287.     'HOUR',
  288.     'HOUR_MINUTE',
  289.     'HOUR_SECOND',
  290.     'IDENTIFIED',
  291.     'IF',
  292.     'IGNORE',
  293.     'IN',
  294.     'INDEX',
  295.     'INDEXES',
  296.     'INFILE',
  297.     'INNER',
  298.     'INSERT',
  299.     'INSERT_ID',
  300.     'INSERT_METHOD',
  301.     'INTERVAL',
  302.     'INTO',
  303.     'IS',
  304.     'ISOLATION',
  305.     'JOIN',
  306.     'KEY',
  307.     'KEYS',
  308.     'KILL',
  309.     'LAST_INSERT_ID',
  310.     'LEADING',
  311.     'LEFT',
  312.     'LEVEL',
  313.     'LIKE',
  314.     'LIMIT',
  315.     'LINES',
  316.     'LOAD',
  317.     'LOCAL',
  318.     'LOCK',
  319.     'LOCKS',
  320.     'LOGS',
  321.     'LOW_PRIORITY',
  322.     'MASTER',
  323.     'MASTER_CONNECT_RETRY',
  324.     'MASTER_HOST',
  325.     'MASTER_LOG_FILE',
  326.     'MASTER_LOG_POS',
  327.     'MASTER_PASSWORD',
  328.     'MASTER_PORT',
  329.     'MASTER_USER',
  330.     'MATCH',
  331.     'MAX_CONNECTIONS_PER_HOUR',
  332.     'MAX_QUERIES_PER_HOUR',
  333.     'MAX_ROWS',
  334.     'MAX_UPDATES_PER_HOUR',
  335.     'MEDIUM',
  336.     'MERGE',
  337.     'MIN_ROWS',
  338.     'MINUTE',
  339.     'MINUTE_SECOND',
  340.     'MODE',
  341.     'MODIFY',
  342.     'MONTH',
  343.     'MRG_MYISAM',
  344.     'MYISAM',
  345.     'NATURAL',
  346.     // 'NO' is not allowed in SQL-99 but is allowed in MySQL
  347.     //'NO',
  348.     'NOT',
  349.     'NULL',
  350.     'ON',
  351.     'OPEN',
  352.     'OPTIMIZE',
  353.     'OPTION',
  354.     'OPTIONALLY',
  355.     'OR',
  356.     'ORDER',
  357.     'OUTER',
  358.     'OUTFILE',
  359.     'PACK_KEYS',
  360.     'PARTIAL',
  361.     'PASSWORD',
  362.     'PRIMARY',
  363.     'PRIVILEGES',
  364.     'PROCEDURE',
  365.     'PROCESS',
  366.     'PROCESSLIST',
  367.     'PURGE',
  368.     'QUICK',
  369.     'RAID0',
  370.     'RAID_CHUNKS',
  371.     'RAID_CHUNKSIZE',
  372.     'RAID_TYPE',
  373.     'READ',
  374.     'REFERENCES',
  375.     'REGEXP',
  376.     'RELOAD',
  377.     'RENAME',
  378.     'REPAIR',
  379.     'REPEATABLE',
  380.     'REPLACE',
  381.     'REPLICATION',
  382.     'RESET',
  383.     'RESTORE',
  384.     'RESTRICT',
  385.     'RETURN',
  386.     'RETURNS',
  387.     'REVOKE',
  388.     'RIGHT',
  389.     'RLIKE',
  390.     'ROLLBACK',
  391.     'ROW',
  392.     'ROW_FORMAT',
  393.     'ROWS',
  394.     'SECOND',
  395.     'SELECT',
  396.     'SERIALIZABLE',
  397.     'SHARE',
  398.     'SHOW',
  399.     'SHUTDOWN',
  400.     'SLAVE',
  401.     'SONAME',
  402.     'SQL_AUTO_IS_NULL',
  403.     'SQL_BIG_RESULT',
  404.     'SQL_BIG_SELECTS',
  405.     'SQL_BIG_TABLES',
  406.     'SQL_BUFFER_RESULT',
  407.     'SQL_CACHE',
  408.     'SQL_CALC_FOUND_ROWS',
  409.     'SQL_LOG_BIN',
  410.     'SQL_LOG_OFF',
  411.     'SQL_LOG_UPDATE',
  412.     'SQL_LOW_PRIORITY_UPDATES',
  413.     'SQL_MAX_JOIN_SIZE',
  414.     'SQL_NO_CACHE',
  415.     'SQL_QUOTE_SHOW_CREATE',
  416.     'SQL_SAFE_UPDATES',
  417.     'SQL_SELECT_LIMIT',
  418.     'SQL_SLAVE_SKIP_COUNTER',
  419.     'SQL_SMALL_RESULT',
  420.     'SQL_WARNINGS',
  421.     'START',
  422.     'STARTING',
  423.     'STATUS',
  424.     'STOP',
  425.     'STRAIGHT_JOIN',
  426.     'STRING',
  427.     'STRIPED',
  428.     'SUPER',
  429.     'TABLE',
  430.     'TABLES',
  431.     'TEMPORARY',
  432.     'TERMINATED',
  433.     'THEN',
  434.     'TO',
  435.     'TRAILING',
  436.     'TRUNCATE',
  437.     'TYPE',
  438.     'UNCOMMITTED',
  439.     'UNION',
  440.     'UNIQUE',
  441.     'UNLOCK',
  442.     'UPDATE',
  443.     'USAGE',
  444.     'USE',
  445.     'USING',
  446.     'VALUES',
  447.     'VARIABLES',
  448.     'WHEN',
  449.     'WHERE',
  450.     'WITH',
  451.     'WORK',
  452.     'WRITE',
  453.     'XOR',
  454.     'YEAR_MONTH'
  455. );
  456. //$PMA_SQPdata_reserved_word_cnt = count($PMA_SQPdata_reserved_word);
  457. $PMA_SQPdata_reserved_word_cnt = 259;
  458.  
  459. $PMA_SQPdata_column_type = array (
  460.     'BIGINT',
  461.     'BIT',
  462.     'BLOB',
  463.     'BOOL',
  464.     'CHAR',
  465.     'CHARACTER',
  466.     'DATE',
  467.     'DATETIME',
  468.     'DEC',
  469.     'DECIMAL',
  470.     'DOUBLE',
  471.     'ENUM',
  472.     'FLOAT',
  473.     'FLOAT4',
  474.     'FLOAT8',
  475.     'INT',
  476.     'INT1',
  477.     'INT2',
  478.     'INT3',
  479.     'INT4',
  480.     'INT8',
  481.     'INTEGER',
  482.     'LONG',
  483.     'LONGBLOB',
  484.     'LONGTEXT',
  485.     'MEDIUMBLOB',
  486.     'MEDIUMINT',
  487.     'MEDIUMTEXT',
  488.     'MIDDLEINT',
  489.     'NCHAR',
  490.     'NUMERIC',
  491.     'REAL',
  492.     'SET',
  493.     'SMALLINT',
  494.     'TEXT',
  495.     'TIME',
  496.     'TIMESTAMP',
  497.     'TINYBLOB',
  498.     'TINYINT',
  499.     'TINYTEXT',
  500.     'VARBINARY',
  501.     'VARCHAR',
  502.     'YEAR'
  503. );
  504. //$PMA_SQPdata_column_type_cnt = count($PMA_SQPdata_column_type);
  505. $PMA_SQPdata_column_type_cnt = 43;
  506.  
  507. ?>
  508.