在querydsl中调用mysql嵌套/内部函数

我需要在QueryDsl Native MySQL中运行以下查询。

SELECT cast(json_unquote(JSON_EXTRACT(vendor_master,'$.vendor.currency')) as char) as currency FROM vendor; 

上面的查询有3个嵌套的mysql函数,如cast,json_unquote和json_extract。 在QueryDsl中,我为每个函数创建了单独的Expression,如下面的代码所示。

  SimpleExpression exp1=Expressions.simpleTemplate(String.class,"json_extract({0},{1})",vendor.vendorMaster,"$.vendor.currency"); SimpleExpression exp2=Expressions.simpleTemplate(String.class,"json_unquote({0})",exp2); SimpleExpression exp3=Expressions.simpleTemplate(String.class,"cast({0} as char) as currency",exp3); List tuples=sqlQueryFactory.select(exp3).from(vendor).fetch(); 

我必须创建更多数量的表达式,而不是函数。 是否可以在单个表达式中调用多个函数以降低复杂性?

我找到了问题的答案。

 SimpleExpression exp=Expressions.simpleTemplate(String.class,"cast(json_unquote(json_extract({0},{1})) as char) as currency",vendor.vendorMaster,"$.vendor.currency"); List tuples=sqlQueryFactory.select(exp).from(vendor).fetch(); 

感谢您的答复。