postgresql查询分析源码分析-流程

本文探讨了PostgreSQL 9.4.4版本的查询分析过程,涉及词法分析、语法分析和语义分析。重点讲解了源码中gram.y、scan.l生成的解析函数,并通过调试exec_simple_query函数,详细解释了pg_parse_query和pg_analyze_and_rewrite在处理SQL语句如'select * from sangli;'时的作用,尤其是targetList和fromClause的解析。最后提到flex和bison在查询分析中的重要性。
摘要由CSDN通过智能技术生成

postgresql version :9.4.4

源码路径:src/backend/parser


所谓查询分析就是把SQL查询语句生成查询树。查询分析是查询编译的第一个模块。主要包括:词法分析,语法分析和语义分析这三个部分。


现在看的源码是9.4.4版本,在9.0词法分析借用了lex,语法分析是yacc。现在是升级的flex跟bison。

在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);


再gdb到这个进程:
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值