Получите ответ в формате JSON из аннотации @Query в Spring
Вместилище
@Repository
public interface TestNativeQRepository extends CrudRepository<TestNativeQ, String> {
@Query( value="SELECT qplt.name price_list_name, qplab.status_code, qplab.start_date, (SELECT charge_definition_code FROM oalfsaas_repl.QP_CHARGE_DEFINITIONS_B WHERE charge_definition_id=qplab.charge_definition_id ) chargedefinitioncode "
+ "FROM pricelistsall qplab, PRICELISTSTL qplt "
+ " WHERE qplab.price_list_id =qplt.price_list_id ", nativeQuery = false)
public List<TestNativeQDTO> getAllDetails();
}
Фактический результат:
[{"ABC", "DEF", "15/05/2018", "XXZ"}]
ожидаемый результат
[{name: "ABC", statuscode: "DEF", startDate: "15/05/2018", chargedefintioncode: "XXZ"}]
Запрос имеет более одной таблицы, а также подзапрос в списке столбцов.
1 ответ
Вам понадобится выражение конструктора: https://javaee.github.io/tutorial/persistence-querylanguage006.html
Например:
SELECT NEW mypackage.TestNativeQDTO(qplt.name price_list_name, qplab.status_code, qplab.start_date, (SELECT charge_definition_code FROM oalfsaas_repl.QP_CHARGE_DEFINITIONS_B WHERE charge_definition_id=qplab.charge_definition_id ) chargedefinitioncode) [...]"
Я не уверен, работает ли он с подзапросами, хотя.