Skip to content
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

Hash arrow (#>, #>>) JSON operators unsupported #502

Open
2 tasks done
naoyak opened this issue Dec 18, 2024 · 2 comments
Open
2 tasks done

Hash arrow (#>, #>>) JSON operators unsupported #502

naoyak opened this issue Dec 18, 2024 · 2 comments
Labels
JSON Something related to JSON support

Comments

@naoyak
Copy link
Contributor

naoyak commented Dec 18, 2024

What happens?

Attempting to query a JSON column with the hash arrow (#> or #>>) operators with pg_duckdb results in a syntax error:

"ERROR: (PGDuckDB/CreatePlan) Prepared query returned an error: 'Parser Error: syntax error at or near \"#\"\nLINE 1: SELECT ((dim_calibrations #>> ARRAY['v1'::text, 'c2h4'::text, 'en...\n                                  ^",

To Reproduce

postgres=# create table dummy(col json) USING duckdb;
CREATE TABLE
postgres=# insert into dummy values ('{"a": {"b": ["foo","bar"]}}'::json);
INSERT 0 0
postgres=# SELECT col #>> '{a,b,1}' from dummy;
ERROR:  (PGDuckDB/CreatePlan) Prepared query returned an error: 'Parser Error: syntax error at or near "#"
LINE 1: SELECT (col #>> '{a,b,1}'::text[]) AS "?column?" FR...
                    ^

OS:

macOS

pg_duckdb Version (if built from source use commit hash):

0.2.0 nightly

Postgres Version (if built from source use commit hash):

17

Hardware:

No response

Full Name:

Naoya Kanai

Affiliation:

Strella

What is the latest build you tested with? If possible, we recommend testing with the latest nightly build.

I have tested with a nightly build

Did you include all relevant data sets for reproducing the issue?

Not applicable - the reproduction does not require a data set

Did you include all code required to reproduce the issue?

  • Yes, I have

Did you include all relevant configuration (e.g., CPU architecture, Linux distribution) to reproduce the issue?

  • Yes, I have
@Leo-XM-Zeng
Copy link
Contributor

It appears that duckdb does not support the "#>>" operator.

@ritwizsinha
Copy link
Contributor

Maybe, we need to add to the IsAllowedStatement function in duckdb hooks to check for #>, #>> and fail gracefully in that case ?

@JelteF JelteF added the JSON Something related to JSON support label Jan 15, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
JSON Something related to JSON support
Projects
None yet
Development

No branches or pull requests

4 participants