postgresql version :9.4.4
源码路径:src/backend/parser
所谓查询分析就是把SQL查询语句生成查询树。查询分析是查询编译的第一个模块。主要包括:词法分析,语法分析和语义分析这三个部分。
在postgresql中,对应的是src/backend/parser/gram.y&scan.l,这2个文件在编译的时候会生成gram.c/h,scan.c
关键字是在src/include/parser/kwlist.h,如果我们想添加一个关键字,可以在这个头文件添加。(注意添加顺序哦)
查询分析的基本流程:
我们现在来看看源码:
首先我们创建一张测试表,插入一条数据.
create table sangli(x text,y text,z bigint);
insert into sangli(x,y,z) values('x','y',99);