PostgreSQL 保留关键字添加方法之二,带参数的函数

以添加 MY_POSITION(substring IN string)为例说明


1、src\backend\parser\gram.y文件的%token <keyword>段添加MY_POSITION关键字,
建议按照ASCII顺序添加


2、src\backend\parser\gram.y文件的函数语义分析段添加如下内容:
----------------------------------------------------------------------
| MY_POSITION '(' my_position_list ')'
{
/*
* my_position(A in B) is converted to strpos(B, A) 
*/
FuncCall *n = makeNode(FuncCall);
n->funcname = SystemFuncName("strpos");
n->args = $3;
n->agg_order = NIL;
n->agg_star = FALSE;
n->agg_distinct = FALSE;
n->func_variadic = FALSE;
n->over = NULL;
n->location = @1;
$$ = (Node *)n;
}
----------------------------------------------------------------------


3、src\backend\parser\gram.y文件中添加如下内容:
----------------------------------------------------------------------
my_position_list:
b_expr IN_P b_expr { $$ = list_make2($3, $1); }
| /*EMPTY*/ { $$ = NIL; }
;
----------------------------------------------------------------------
这里的“IN”已经是关键字了,可以直接用IN_P 

4、src\backend\parser\gram.y文件的col_name_keyword段,添加MY_POSITION,如
----------------------------------------------------------------------
| MY_POSITION
----------------------------------------------------------------------


5、src\backend\parser\gram.y文件的定义段增加如下内容:
----------------------------------------------------------------------
%type <list> my_position_list
----------------------------------------------------------------------


6、src\include\parser\kwlist.h文件中增加如下语句(※):
----------------------------------------------------------------------
PG_KEYWORD("my_position", MY_POSITION, COL_NAME_KEYWORD)
----------------------------------------------------------------------
※:添加时,位置是按照ASCII顺序排列的。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值