Получите ответ в формате 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) [...]"

Я не уверен, работает ли он с подзапросами, хотя.

Другие вопросы по тегам