【问题标题】:Call mysql nested/inner functions in querydsl在querydsl中调用mysql嵌套/内部函数
【发布时间】:2017-05-23 11:55:01
【问题描述】:

我需要在 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 中,我为每个函数创建了单独的表达式,如下面的代码所示。

    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();

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

【问题讨论】:

    标签: java mysql querydsl


    【解决方案1】:

    我找到了问题的答案。

    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();
    

    感谢您的回复。

    【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2016-11-13
    • 2014-05-23
    • 1970-01-01
    • 2012-11-20
    • 1970-01-01
    • 2017-06-21
    • 2021-05-19
    相关资源
    最近更新 更多