首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在querydsl中调用mysql嵌套/内部函数

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

Stack Overflow用户
提问于 2017-01-09 17:03:01
回答 1查看 1.8K关注 0票数 4

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

代码语言:javascript
复制
SELECT cast(json_unquote(JSON_EXTRACT(vendor_master,'$.vendor.currency')) as char) as currency FROM vendor;

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

代码语言:javascript
复制
    SimpleExpression<String> exp1=Expressions.simpleTemplate(String.class,"json_extract({0},{1})",vendor.vendorMaster,"$.vendor.currency");
SimpleExpression<String> exp2=Expressions.simpleTemplate(String.class,"json_unquote({0})",exp2);
SimpleExpression<String> exp3=Expressions.simpleTemplate(String.class,"cast({0} as char) as currency",exp3);
List<Tuple> tuples=sqlQueryFactory.select(exp3).from(vendor).fetch();

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

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-01-10 17:42:31

我找到了这个问题的答案。

代码语言:javascript
复制
SimpleExpression<String> exp=Expressions.simpleTemplate(String.class,"cast(json_unquote(json_extract({0},{1})) as char) as currency",vendor.vendorMaster,"$.vendor.currency"); 
List<Tuple> tuples=sqlQueryFactory.select(exp).from(vendor).fetch();

感谢您的回复。

票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41544332

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档