mirror of
https://github.com/aljazceru/turso.git
synced 2026-01-10 19:54:24 +01:00
## Purpose * Implement `setObject(int, Object)` to support binding of common Java types to SQL parameters in JDBC4. * This implementation currently covers only standard JDBC4 supported types. LOB and stream bindings are not yet implemented. ## Changes * Implemented JDBC4PreparedStatement#setObject(int, Object) handling for * `String`, `Integer`, `Long`, `Boolean`, `Double`, `Float`, `Byte`, `Short` * `byte[]`, `Date`, `Time`, `Timestamp`, `BigDecimal` * Added validation for unsupported types (`Blob`, `Clob`, `InputStream`, `Reader`) * Added corresponding unit test `testSetObjectCoversAllSupportedTypes` to verify correctness ## Note * Additional work (e.g., LOB/Stream handling) will be addressed separately once driver support is available. ## Related Issue #615 Reviewed-by: Kim Seon Woo (@seonWKim) Closes #3864
Turso JDBC Driver
The Turso JDBC driver is a library for accessing and creating Turso database files using Java.
Project Status
The project is actively developed. Feel free to open issues and contribute.
To view related works, visit this issue.
How to use
Currently, we have not published to the maven central. Instead, you can locally build the jar and deploy it to maven local to use it.
Build jar and publish to maven local
$ cd bindings/java
# Please select the appropriate target platform, currently supports `macos_x86`, `macos_arm64`, `windows` and `linux_x86`
$ make macos_x86
# deploy to maven local
$ make publish_local
Now you can use the dependency as follows:
dependencies {
implementation("tech.turso:turso:0.0.1-SNAPSHOT")
}
Code style
- Favor composition over inheritance. For example,
JDBC4Connectiondoesn't implementTursoConnection. Instead, it includesTursoConnectionas a field. This approach allows us to preserve the characteristics of Turso usingTursoConnectioneasily while maintaining interoperability with the Java world usingJDBC4Connection.