machristie opened a new issue, #27:
URL: https://github.com/apache/airavata-data-catalog/issues/27

   The Calcite integration only support queries against pre-registered metadata 
schema fields, like so
   ```sql
   SELECT
       *
   FROM
       my_schema
   WHERE
       (
           field1 < 5
           OR field3 = 'bar'
       )
       AND field1 > 0
       AND external_id = 'fff';
   ```
   
   But it would be nice if one could query against unregistered metadata schema 
fields that are known to exist within the metadata JSONB column, something like:
   ```sql
   SELECT
       *
   FROM
       my_schema
   WHERE
       metadata.some_other_field > 0;
   ```
   
   There are two challenges. One is how to relax Calcite's validation to allow 
referencing fields that aren't known ahead of time. Second is how to support a 
syntax for referencing a JSON field that Calcite will parse.
   
   One option might be to have the client queries use JSON functions that 
Calcite supports: https://calcite.apache.org/docs/reference.html#json-functions
   
   For example:
   ```sql
   SELECT
       *
   FROM
       my_schema
   WHERE
       JSON_EXISTS(metadata, '$.some_other_field > 0');
   ```
   
   But, PostgreSQL doesn't yet natively support these functions (see 
https://www.depesz.com/2022/04/01/waiting-for-postgresql-15-sql-json-query-functions/)
 so they would need to be rewritten. 


-- 
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.

To unsubscribe, e-mail: [email protected]

For queries about this service, please contact Infrastructure at:
[email protected]

Reply via email to