2017-01-09 2 views
1

QueryDslネイティブMySQLで次のクエリを実行する必要があります。querydslでmysqlのネスト/インナー関数を呼び出す

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

上記のクエリは、鋳造、json_unquoteとjson_extractとしてネストされている3つのMySQLの機能を有しています。 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(); 

関数の数だけ多くの式を作成する必要があります。複雑さを軽減するために、1つの式で複数の関数を呼び出すことは可能ですか?

答えて

2

質問の回答が見つかりました。

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

ご回答ありがとうございます。

+0

あなたは私の時間を保存しました。どうもありがとう。 – spr

関連する問題