5.1 KiB
Q: Squash is same as Exposed. Where is the difference?
A: Ilya Ryzhenkov (Squash maintainer) answers:
Squash is an attempt to refactor Exposed (long time ago) to fix DSL issues, extensibility on dialect side, support graph fetching and avoid TLS-stored transactions. Unfortunately, I didn’t have enough time to finish the work, but I still hope to return to it some day. We are talking with Exposed maintainer @tapac about coordinating efforts and eventually joining forces. Note, that none of these libs are “official” JetBrains Kotlin SQL libs, they are both side projects of their respective authors.
Q: Can I use multiple Database Connections?
A: Yes. See Working with a multiple databases
Q: Is Array column type supported?
A: Not at the moment. More info here: https://github.com/JetBrains/Exposed/issues/150
The complete list of supported data types can be found here: Data Types.
Q: Is upsert supported?
A: Upsert is an instruction to the Database to insert a new row or update existing row based on a table key. It is not supported as part of the library but it is possible to implement on top of it. See this issue: https://github.com/JetBrains/Exposed/issues/167 and example here: https://medium.com/@OhadShai/first-steps-with-kotlin-exposed-cb361a9bf5ac
Q: Is json type supported?
A: Not at the moment. Here is the issue: https://github.com/JetBrains/Exposed/issues/127
The complete list of supported data types can be found here: Data Types.
Q: How to get a plain SQL query which will be executed?
A:
val plainSQL = FooTable.select {}.prepareSQL(QueryBuilder(false))
Use QueryBuiler with false - if you want to inline statement arguments, true - to see '?' in query.
Q: Is it possible to use native sql / sql as a string?
A: It is not supported as part of the library but it is possible to implement on top of it and use it like this:
fun <T:Any> String.execAndMap(transform : (ResultSet) -> T) : List<T> {
val result = arrayListOf<T>()
TransactionManager.current().exec(this) { rs ->
while (rs.next()) {
result += transform(rs)
}
}
return result
}
"select u.name, c.name from user u inner join city c where blah blah".execAndMap { rs ->
rs.getString("u.name") to rs.getString("c.name")
}
More info in this issue: https://github.com/JetBrains/Exposed/issues/118
Q: Is it possible to update a field relative to current field value?
A: Yes. See example here: https://github.com/JetBrains/Exposed/wiki/DSL#update
Q: How can I add another type of Database?
A: Implement DatabaseDialect interface and register it with Database.registerDialect().
If the implementation adds a lot of value consider contributing it as a PR to Exposed.
Q: Is it possible to create tables with cross / cyclic reference?
A: Yes, it's possible since Exposed 0.11.1 version
Q: How can I implement nested queries?
A: See example here: https://github.com/JetBrains/Exposed/issues/248
Q: SQLite3 fails with the error Transaction attempt #0 failed: SQLite supports only TRANSACTION_SERIALIZABLE and TRANSACTION_READ_UNCOMMITTED.
A: Make your connect code look like below (taken from ThreadLocalManagerTest.kt). The setting below tells SQLite3 to enforce transactional integrity by serializing writes from different connections.
// Your connection properties here
Database.connect("jdbc:sqlite:my.db", "org.sqlite.JDBC")
TransactionManager.manager.defaultIsolationLevel = Connection.TRANSACTION_SERIALIZABLE // Or Connection.TRANSACTION_READ_UNCOMMITTED
Q: Oracle fails with the error Transaction attempt #0 failed: READ_COMMITTED and SERIALIZABLE are the only valid transaction levels
A: Make your connect code look like below (taken from ThreadLocalManagerTest.kt).
// Your connection properties here
Database.connect("jdbc:jdbc:oracle:thin:@//localhost:1521/test", "oracle.jdbc.OracleDriver")
TransactionManager.manager.defaultIsolationLevel = Connection.TRANSACTION_SERIALIZABLE // Or Connection.TRANSACTION_READ_COMMITTED
Q: How can I use SAVEPOINT?
A: It possible only through using a raw connection. See example here.
Q: How to prepare query like: SELECT * FROM table WHERE (x,y) IN ((1, 2), (3, 4), (5, 6))
A: It possible with custom function. See example.