在 querydsl 中调用 mysql nested/inner 函数
Call mysql nested/inner functions in querydsl
我需要 运行 在 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();
我必须创建与函数数量一样多的表达式。是否可以在单个表达式中调用多个函数以降低复杂性?
我找到了问题的答案。
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();
感谢您的回复。
我需要 运行 在 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();
我必须创建与函数数量一样多的表达式。是否可以在单个表达式中调用多个函数以降低复杂性?
我找到了问题的答案。
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();
感谢您的回复。