对PostgreSQL语法分析中 targetlist 的理解

在 gram.y 中:

复制代码
simple_select:                                
            SELECT    opt_distinct    target_list                    
            into_clause     from_clause     where_clause                    
            group_clause     having_clause    window_clause                    
                {                
                    SelectStmt *n = makeNode(SelectStmt);            
                    n->distinctClause = $2;            
                    n->targetList = $3;            
                    n->intoClause = $4;            
                    n->fromClause = $5;            
                    n->whereClause = $6;            
                    n->groupClause = $7;            
                    n->havingClause = $8;            
                    n->windowClause = $9;            
                    $$ = (Node *)n;            
                }                
                                
……       
复制代码
把它修改一下,增加:

复制代码
simple_select:                                
            SELECT    opt_distinct    target_list                    
            into_clause     from_clause     where_clause                    
            group_clause     having_clause    window_clause                    
                {                
                    SelectStmt *n = makeNode(SelectStmt);            
                    n->distinctClause = $2;            
                    n->targetList = $3;            
                    n->intoClause = $4;            
                    n->fromClause = $5;            
                    n->whereClause = $6;            
                    n->groupClause = $7;            
                    n->havingClause = $8;            
                    n->windowClause = $9;            
                    $$ = (Node *)n;
                    fprintf(stderr,"length of list: %d\n", n->targetList->length);
            
                }                
                                
……                                 
复制代码
psql 中执行: select id, name from a8;

后台出现: length of list: 2


本文转自健哥的数据花园博客园博客,原文链接:http://www.cnblogs.com/gaojian/archive/2012/09/06/2673589.html,如需转载请自行联系原作者
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值