对PostgreSQL语法分析中 targetlist 的理解

本文涉及的产品
云原生数据库 PolarDB MySQL 版,Serverless 5000PCU 100GB
云原生数据库 PolarDB PostgreSQL 版,企业版 4核16GB
推荐场景:
HTAP混合负载
云原生数据库 PolarDB MySQL 版,通用型 2核4GB 50GB
简介:
在 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,如需转载请自行联系原作者
相关实践学习
使用PolarDB和ECS搭建门户网站
本场景主要介绍基于PolarDB和ECS实现搭建门户网站。
阿里云数据库产品家族及特性
阿里云智能数据库产品团队一直致力于不断健全产品体系,提升产品性能,打磨产品功能,从而帮助客户实现更加极致的弹性能力、具备更强的扩展能力、并利用云设施进一步降低企业成本。以云原生+分布式为核心技术抓手,打造以自研的在线事务型(OLTP)数据库Polar DB和在线分析型(OLAP)数据库Analytic DB为代表的新一代企业级云原生数据库产品体系, 结合NoSQL数据库、数据库生态工具、云原生智能化数据库管控平台,为阿里巴巴经济体以及各个行业的企业客户和开发者提供从公共云到混合云再到私有云的完整解决方案,提供基于云基础设施进行数据从处理、到存储、再到计算与分析的一体化解决方案。本节课带你了解阿里云数据库产品家族及特性。
目录
相关文章
|
关系型数据库 PostgreSQL
|
关系型数据库 PostgreSQL
|
关系型数据库 PostgreSQL
|
关系型数据库 PostgreSQL
|
关系型数据库 PostgreSQL
|
关系型数据库 PostgreSQL
|
关系型数据库 PostgreSQL
|
2天前
|
存储 关系型数据库 MySQL
|
1天前
|
存储 关系型数据库 MySQL