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

feat: struct, list, and map parameter support #30

Merged
merged 17 commits into from
Jun 12, 2024

Conversation

Mause
Copy link
Member

@Mause Mause commented Jun 10, 2024

No description provided.

@Mause Mause merged commit 329b9aa into duckdb:main Jun 12, 2024
6 checks passed
@Mause Mause deleted the feature/jdbc-struct branch June 12, 2024 10:02
@rayokota
Copy link
Contributor

@Mause , any idea on when this will be released?

@Mause
Copy link
Member Author

Mause commented Jun 30, 2024

@Mause , any idea on when this will be released?

It will be included in the next DuckDB release

https://duckdb.org/docs/dev/release_calendar

@StephenFlavin
Copy link

StephenFlavin commented Jul 27, 2024

Hi @Mause,

I was excited to see support for Connection#createArrayOf was added so I decided to build locally to try it out and I came across one issue and a question on performance.

Issue:

connection.createArrayOf("timestamp", new Instant[] {Instant.now()} )

produces an error

...
Caused by: java.sql.SQLException: Invalid Input Error: Unsupported parameter type
	at org.duckdb.DuckDBNative.duckdb_jdbc_execute(Native Method)
	at org.duckdb.DuckDBPreparedStatement.execute(DuckDBPreparedStatement.java:142)
	at org.duckdb.DuckDBPreparedStatement.executeQuery(DuckDBPreparedStatement.java:174)
Caused by: java.sql.SQLException: Invalid Input Error: Unsupported parameter type

Not sure if this is intentional for now or an oversight

Performance Question:

Before I saw that this had been implemented I passed arrays as literals from java then casting the parameter to the array type in the sql, it seems passing the array literal is many times faster than using Connection#createArrayOf, I tried similar on postgres in the past and the speed improvement using Connection#createArrayOf was significant.
Quick test code (using spring)

    public static void main(String[] args) throws SQLException {
        var jdbcClient = JdbcClient.create(new SingleConnectionDataSource("jdbc:duckdb:", true));

        jdbcClient.sql("create table foo(i int)")
                        .update();

        String arrayLiteral = IntStream.range(0, 10000).mapToObj(String::valueOf).collect(Collectors.joining(",", "[", "]"));

        System.out.println("ArrayLiteral");

        for (int i = 0; i < 100; i++) {
            final var now2 = Instant.now();
            jdbcClient.sql("insert into foo select unnest(:arr::int[])")
                    .param("arr", arrayLiteral)
                    .update();
            final var duration = Duration.between(now2, Instant.now());
            System.out.println(duration.toNanos() / 1000000d);
        }

        jdbcClient.sql("truncate table foo")
                .update();

        System.out.println("`Connection#createArrayOf`");

        final var elements = IntStream.range(0, 10000).boxed().toArray();

        try (final var connection = new SingleConnectionDataSource("jdbc:duckdb:", true).getConnection()) {
            for (int i = 0; i < 100; i++) {
                final var now = Instant.now();
                jdbcClient.sql("insert into foo select unnest(:arr::int[])")
                        .param("arr", connection.createArrayOf("int4", elements))
                        .update();
                final var duration = Duration.between(now, Instant.now());
                System.out.println(duration.toNanos() / 1000000d);
            }
        }
    }

output on M1 mac showing 1.3ms for array literal vs 6.4ms for Connection#createArrayOf, is this expected as a first implementation or do you think something is a rye?

unfortunately, I've not got the time to dig into potential performance improvements on the java side and I don't know c++ so can't help there 😓

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants