Avatar of ltpitt
ltpitt

asked on 

How can I sort a field from Swagger if the query contains a Join?

Hi all,

I serve using Spring Boot via Swagger the following endpoint:

   @Query("select a from Table a " +
      " join a.team t " +
      " join a.user u " +
      " join a.role r " +
      " where lower(t.name) like lower(concat('%', :filter, '%'))" + SQLESCAPE +
      " or lower(t.field1) like lower(concat('%', :filter, '%'))" + SQLESCAPE +
      " or lower(t.field2) like lower(concat('%', :filter, '%'))" + SQLESCAPE +
      " or lower(u.field3) like lower(concat('%', :filter, '%'))" + SQLESCAPE +
      " or lower(r.field4) like lower(concat('%', :filter, '%'))" + SQLESCAPE)
   )
   Page<Role> findRolesByTypeInAndFilter(@Param("filter") String filter, Pageable pageable);

Open in new window


It works perfectly but when the user wants to sort I can only sort fields that are NOT in the joins (only fields available in Table).

If user specify the full field name (e.g. u.field3) it works perfectly,

What can I do to let the user just use, for examlpe, field3 for sorting?

Thanks!
Java* swaggerSQL

Avatar of undefined
Last Comment
ltpitt
ASKER CERTIFIED SOLUTION
Avatar of Kevin Cross
Kevin Cross
Flag of United States of America image

Blurred text
THIS SOLUTION IS ONLY AVAILABLE TO MEMBERS.
View this solution by signing up for a free trial.
Members can start a 7-Day free trial and enjoy unlimited access to the platform.
See Pricing Options
Start Free Trial
Avatar of ltpitt
ltpitt

ASKER

Thanks for your help, Kevin!
Java
Java

Java is a platform-independent, object-oriented programming language and run-time environment, designed to have as few implementation dependencies as possible such that developers can write one set of code across all platforms using libraries. Most devices will not run Java natively, and require a run-time component to be installed in order to execute a Java program.

102K
Questions
--
Followers
--
Top Experts
Get a personalized solution from industry experts
Ask the experts
Read over 600 more reviews

TRUSTED BY

IBM logoIntel logoMicrosoft logoUbisoft logoSAP logo
Qualcomm logoCitrix Systems logoWorkday logoErnst & Young logo
High performer badgeUsers love us badge
LinkedIn logoFacebook logoX logoInstagram logoTikTok logoYouTube logo