-
Notifications
You must be signed in to change notification settings - Fork 350
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
Introduce abstractions to define custom criteria predicates #1953
Comments
You are correct, there is currently no special support for this operator. I'm also not sure if it makes sense to support all the operators (and functions) that one database or another supports. Instead we should come up with a way to define arbitrary criteria, or extend Criteria in a simple way, so that users can provide there own operators and functions. |
I believe the most straightforward and simple solution would be to add a new constructor method to Criteria, allowing developers to pass in custom string conditions, which can then be parsed into the framework's internal Condition object. For example, an expression like tags @> ARRAY['electronics']::text[], which essentially represents a database comparison operation, can be mapped to the Comparison type within the framework. This way, users can conveniently utilize database-specific operators (such as PostgreSQL's @>), without breaking the existing structure and design principles of Criteria. At its core, I believe the framework should at least provide users with an option to support custom operators, rather than limiting them to the predefined set of operators. This would not only enhance the flexibility of the framework but also meet the demands of users dealing with specific database features or complex business scenarios. At the same time, it would preserve the ability to generate and control the underlying SQL. To be candid, I'm not very familiar with this framework yet, and I've only taken a brief look at its code. Therefore, this is just an initial idea based on intuition. If there's anything inappropriate in it, I would appreciate some feedback and guidance. I strongly believe that having a mechanism to support custom operators would be a great complement to the framework's extensibility. |
Perhaps I can provide a PR to try implementing this feature? |
That would be nice. |
Taking a step back from the actual problem there is a problem space around database-specific operations that we would like to surface through We cannot provide all operators through the generic Criteria API as running queries against a different database that doesn't support these would just not work. Likely, a user would like to write something like:
rendering into: tags @> ARRAY[?]::text[] Bear with me, I'm not exactly sure whether parameter binding works inside the To make this work, we need predicates to apply mapping, specify binding parameters and to generate SQL text. Going further, one might would want to express: json_array_length(my_json_column) > 5 When considering an abstraction for predicates, we should also spend a bit of time to consider how the example above could be represented and what pieces it would require to make it work. Java code could look like the following:
So these are my thoughts around dialect-specific predicates so far. |
Thank you, @mp911de, that makes sense. And I generally agree with you. However, we need to understand, that there are a lot of possible predicates that are vendor specific, and it would certainly make sense to support with type safe built-in API, that you depicted. That totally makes sense to me. However, my concern is that we need to have both approaches - hear me out, please**. Sometimes, the expression is just really tooooo complex, and we just cannot handle it via our type safe API. Apart from that, if we would add support for Postgres Arrays and JSONB, other people would request features similar to that. That is often the case. We can provide this solution as a final fallback if we either cannot implement the type safe API for this exact vendor's feature, or we consider it not to be reasonable. At least we have a fallback solution, and we do not just leave users with nothing - that is my point. The people want to get their things done, and type safe API is definitely better, but maybe let's add it on top of this solution? |
Yeah, I think about a general foundation that enables building custom predicates and then, as we progress with our implementation, we would add operators and predicates that we support. The general fallback is a fully custom SQL statement for now. We can explore other alternatives as we progress that allow a smaller scope than the full statement. |
The problem with custom SQL via I'm an active user of the Spring Data JDBC myself and my colleages are as well, and we, as many others, use the |
I am using Spring Data R2DBC with a PostgreSQL database. My goal was to use
CriteriaDefinition
to describe a query for a column of typetext[]
in PostgreSQL. Specifically, I wanted to perform array-related operations such as checking if the array contains a value (using the PostgreSQL@>
operator).For example, I expected to write something like this:
However, I could not find any built-in support for such array operators in
CriteriaDefinition
. This left me wondering if I have missed some part of the documentation or if this functionality is not supported.The lack of array operator support means that for now, I would have to resort to raw SQL for such queries, like this:
This feels frustrating, especially because I want to leverage the abstraction of
R2dbcEntityTemplate
and avoid writing raw SQL. Is there currently a way to describe such queries usingCriteriaDefinition
, or are array-related operations not yet supported for PostgreSQL?I would greatly appreciate any insights or guidance on this topic.
The text was updated successfully, but these errors were encountered: