mirror of https://github.com/postgres/postgres
(which now deals only in optimizable statements), and put that code into a new file parser/parse_utilcmd.c. This helps clarify and enforce the design rule that utility statements shouldn't be processed during the regular parse analysis phase; all interpretation of their meaning should happen after they are given to ProcessUtility to execute. (We need this because we don't retain any locks for a utility statement that's in a plan cache, nor have any way to detect that it's stale.) We are also able to simplify the API for parse_analyze() and related routines, because they will now always return exactly one Query structure. In passing, fix bug #3403 concerning trying to add a serial column to an existing temp table (this is largely Heikki's work, but we needed all that restructuring to make it safe).REL8_3_STABLE
parent
ec0bb02db8
commit
46379d6e60
@ -1,20 +1,21 @@ |
||||
This directory does more than tokenize and parse SQL queries. It also |
||||
creates Query structures for the various complex queries that is passed |
||||
creates Query structures for the various complex queries that are passed |
||||
to the optimizer and then executor. |
||||
|
||||
parser.c things start here |
||||
scan.l break query into tokens |
||||
scansup.c handle escapes in input |
||||
scansup.c handle escapes in input strings |
||||
keywords.c turn keywords into specific tokens |
||||
gram.y parse the tokens and fill query-type-specific structures |
||||
analyze.c handle post-parse processing for each query type |
||||
analyze.c top level of parse analysis for optimizable queries |
||||
parse_clause.c handle clauses like WHERE, ORDER BY, GROUP BY, ... |
||||
parse_coerce.c used for coercing expressions of different types |
||||
parse_coerce.c handle coercing expressions to different types |
||||
parse_expr.c handle expressions like col, col + 3, x = 3 or x = 4 |
||||
parse_oper.c handle operations in expressions |
||||
parse_oper.c handle operators in expressions |
||||
parse_agg.c handle aggregates, like SUM(col1), AVG(col2), ... |
||||
parse_func.c handle functions, table.column and column identifiers |
||||
parse_node.c create nodes for various structures |
||||
parse_target.c handle the result list of the query |
||||
parse_relation.c support routines for tables and column handling |
||||
parse_type.c support routines for type handling |
||||
parse_utilcmd.c parse analysis for utility commands (done at execution time) |
||||
|
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,28 @@ |
||||
/*-------------------------------------------------------------------------
|
||||
* |
||||
* parse_utilcmd.h |
||||
* parse analysis for utility commands |
||||
* |
||||
* |
||||
* Portions Copyright (c) 1996-2007, PostgreSQL Global Development Group |
||||
* Portions Copyright (c) 1994, Regents of the University of California |
||||
* |
||||
* $PostgreSQL: pgsql/src/include/parser/parse_utilcmd.h,v 1.1 2007/06/23 22:12:52 tgl Exp $ |
||||
* |
||||
*------------------------------------------------------------------------- |
||||
*/ |
||||
#ifndef PARSE_UTILCMD_H |
||||
#define PARSE_UTILCMD_H |
||||
|
||||
#include "parser/parse_node.h" |
||||
|
||||
|
||||
extern List *transformCreateStmt(CreateStmt *stmt, const char *queryString); |
||||
extern List *transformAlterTableStmt(AlterTableStmt *stmt, |
||||
const char *queryString); |
||||
extern IndexStmt *transformIndexStmt(IndexStmt *stmt, const char *queryString); |
||||
extern void transformRuleStmt(RuleStmt *stmt, const char *queryString, |
||||
List **actions, Node **whereClause); |
||||
extern List *transformCreateSchemaStmt(CreateSchemaStmt *stmt); |
||||
|
||||
#endif /* PARSE_UTILCMD_H */ |
Loading…
Reference in new issue