Thread: need help

need help

From
vamsi krishna
Date:
hi,  i want to know how CREATE table (creating a
relation)

works in Postgres.where can i find this in source
code.

also i want to know how postgres parser the
input(create table) and how is this connected to  the
create table source code files.


__________________________________________________
Do You Yahoo!?
Tired of spam?  Yahoo! Mail has the best spam protection around 
http://mail.yahoo.com 


Re: need help

From
Neil Conway
Date:
vamsi krishna wrote:
> hi,
>    i want to know how CREATE table (creating a
> relation)

See DefineRelation() in backend/commands/tablecmds.c, and the routines 
it calls.

> also i want to know how postgres parser the
> input(create table) and how is this connected to  the
> create table source code files.

See the CreateStmt production in backend/parser/gram.y (circa line 1509 
in current sources). CREATE TABLE is a utility statement, so a 
high-level view of the processing is:

- the query string is scanned (scan.l) and parsed (gram.y), producing a 
raw parse tree
- in the analysis phase, transformCreateStmt() does a few simple 
transformations of the raw parse tree and produces a Query representing 
the CREATE TABLE utility statement
- ProcessUtility() in backend/tcop/utility.c invokes DefineRelation()

-Neil