如何在groovy模板中保留$符号

1 篇文章 0 订阅

背景

原有功能是这样子的,我们允许用户写一个sql模板,通过${xxx}来动态传入参数。于是用到了groovy的模板功能,在构造sql的时候,使用模板来对参数进行动态调整。简单代码如下:

    String script = "SELECT  id, name, age, detail FROM student WHERE grade=${grade}";
    ScriptEngineManager factory = new ScriptEngineManager();
    SimpleTemplateEngine engine = new SimpleTemplateEngine();
    Map<String, Object> bindings = new HashMap<>();
    bindings.put("grade", "2021");
    System.out.println(engine.createTemplate(script).make(bindings).toString());
	// 输出 SELECT  id, name, age FROM student WHERE grade=2021

在表中,’detail’是一个json字段。用hive的函数GET_JSON_OBJECT()来解析json获取里面的字段,于是script变成了

	String script = "SELECT  id, name, age, GET_JSON_OBJECT(detail, '$.telephone') FROM student WHERE grade=${grade}";

但是改成这样之后,发现一个问题,hive的这个函数使用了groovy的保留字符$,于是在构建sql的时候会报错。

Exception in thread "main" groovy.lang.GroovyRuntimeException: Failed to parse template script (your template may contain an error or be trying to use expressions not currently supported): startup failed:
SimpleTemplateScript1.groovy: 1: token recognition error at: '.' @ line 1, column 63.
   ge, GET_JSON_OBJECT(detail, '$.telephone
                                 ^

可以看到,这边还是把$认为是groovy template的占位符。

解决方案

首先不得不吐槽一下国内博客的质量。。。但即使去外网找,资料也少的可怜。只能自己思考,一个个方案试错。
最终解决方案很简单,即将函数GET_JSON_OBJECT()中的$变成转义字符\\$,即可通过。

    String script = "SELECT  id, name, age, GET_JSON_OBJECT(detail, '\\$.telephone') FROM student WHERE grade=${grade}";
    ScriptEngineManager factory = new ScriptEngineManager();
    SimpleTemplateEngine engine = new SimpleTemplateEngine();
    Map<String, Object> bindings = new HashMap<>();
    bindings.put("grade", "2021");
    System.out.println(engine.createTemplate(script).make(bindings).toString());
	//输出:SELECT  id, name, age, GET_JSON_OBJECT(detail, '$.telephone') FROM student WHERE grade=2021

但是还有一个坑。在代码中测试的时候,字符串中的值应该记为\\$,而在保存前端修改保存到数据库的时候,应该记为\$

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值