-
Notifications
You must be signed in to change notification settings - Fork 1.9k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Allow DQL search or publish parsing library to generate query from DQL #9498
Comments
Just wanted to call out that Your example query would be:
In general, though, a DQL query builder would be pretty nice. |
In order to add this to OpenSearch itself, we would need a way to support the @austintlee suggested maybe separating the formal grammar from the Peggy implementation. Basically:
but also
@Galardolind - would you be interested/willing to bring this issue up for discussion at OpenSearch Dashboards office hours? See https://www.meetup.com/opensearch/events/294620421/ for details. |
Would be great to have that in the query_string documentation, but agree too that DQL would simplify a lot more to the point that it is almost not necessary to learn something as it would be really close to natural language.
Signed up, thanks for the suggestion 👍 |
A summary from the Dashboards office hours about this topic: The reason for this request is because DQL is a simple language to use to search with, its desirable to have it accessible directly through an API as opposed to being only available through OSD's UI. There are a few ways to do this
Personally the easiest solution here is to see if PPL satisfies the requirements and if not look to see what the gap are. I also like the idea of moving DQL to core since it makes the backend easier to access with a simplified language that already support in Dashboards. Would love to hear opinions from some of the maintainers of this repo about the solutions here. @nknize @dblock @andrross and even folks working on PPL @anirudha |
In the Search Relevance community meeting, @lukas-vlcek made a really good point that Peggy (what DQL uses for its grammar) excels at offering contextual hints on errors and autocomplete suggestions. If that part, plus the part that converts from DQL into query DSL, were made available to application developers to use in their frontend (essentially option 3 from @ashwin-pc's comment), it could provide a good "power-user" experience. Adding DQL support to the OpenSearch backend (either as a core feature, a module, or a plugin) might be nice, but we probably wouldn't want to remove support from OSD, because of those nice Peggy features. At that point, we would need to maintain the Peggy JS implemented in OSD and some Java implementation in the backend and make sure their grammars are kept in sync (hence @austintlee's suggestion above of deriving both from some canonical grammar). |
Hi, are there any plans to implement this in near future? |
Is your feature request related to a problem? Please describe.
Searching using OpenSearch API requires a lot of documentation reading and requires to find samples ending often in copy pasting without really understanding why the query is formatted this way.
The documentation is there but split into dozens of pages due to how complex query can be, this result in making simple query unnecessarily complex to write.
OpenSearch already have DQL that would simplify greatly these requests.
Exemple of a simple DQL query with the complex result in JSON:
Describe the solution you'd like
Export existing DQL parser as an npm library to allow DQL integration to any frontend application.
Or
Having a new type of full-text search
query_dsl
that will take a DQL (or alike) query and does the parsing and search in the backend would simplify future integration with OpenSearch as the learning required to learn DQL is way smaller than the current JSON implementation.Exemple:
Describe alternatives you've considered
query_string covers part of it but does not allow any comparators.
Additional context
The text was updated successfully, but these errors were encountered: