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

Statement Dialect Extensions and JDBCTransaction.resultFor(statement) #36

Open
codesplode opened this issue Dec 27, 2020 · 0 comments
Open

Comments

@codesplode
Copy link
Contributor

First off, I hope the jetbrains team has had a wonderful holiday season and stayed safe & healthy during these times.

JDBCTransaction.resultFor() is a troubling method when creating Dialect Extensions, such as MySQL's extended insert statement.

This is because it performs logic to get the result of a statement, with no access to the generic type in Statement and is checks that depend on specific query classes (InsertValuesStatement, InsertQueryStatement, DeleteQueryStatement, etc.) It also throws an error for anything it does not match, making all new statement types fail by default. This means a query/statement dialect extension could not be made unless it extends an existing query type directly.

We have implemented the MySQL insert statement with multiple values lines by modifying the code to have a StatementWithoutResult flag interface that simply extends Statement in the JDBC module, and added that to the when statement in resultFor. This would work at some level for most queries, but we would like to ask @orangy for his input regarding how best to achieve this in Kotlin if there is a better way without flag interfaces or passing class references around as a contructor arg and which the jetbrains team would prefer, so that we may better our knowledge / reasoning.

We have also continued our development on squash quite a bit and would love to work with you when you surface @orangy !

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

No branches or pull requests

1 participant