-
Notifications
You must be signed in to change notification settings - Fork 15
Home
Relate is a lightweight database access layer for Scala that simplifies database interaction while leaving complete control over the actual SQL query. It was developed at Lucid Software in response to a need for increasingly performant database access software and seeks to abstract away the PreparedStatement's idiosyncrasies while maintaining its speed.
- Works with all JDBC connection types
- Works with all database engines
- Performance
- Create connections to databases
- ORM abstraction
The core action in using Relate is writing SQL queries that contain named parameters and then calling functions to replace those parameters with their values. Here's a simple example to start with:
import com.lucidchart.open.relate._
import com.lucidchart.open.relate.Query._
SQL("""
UPDATE pokemon
SET move2={move}
WHERE id={id} AND name={name}
""").on { implicit query =>
int("id", 25)
string("name", "Pikachu")
string("move", "Thundershock")
}.executeUpdate()(connection)
This code snippet is faintly similar to using PreparedStatement. One must first write a SQL query, which is done in Relate by passing the query to the SQL function as a string. Placeholders in the query are specified by placing a parameter name between curly braces.
Next, the on method is used to insert values into query parameters. Parameter insertion is performed in an anonymous function passed to on. Within the function, methods with names corresponding to parameter type are called with parameter name and value as arguments. For convenience, if the query object is declared as an implicit parameter and there is an import for com.lucidchart.open.relate.Query._ in scope, insertion methods can be called directly without calling them on the query object.
Finally, executing the query requires a java.sql.Connection parameter in a second parameter list. If the Connection is in the implicit scope, it does not need to be provided to the execute method. All queries defined in PreparedStatement (execute, executeInsert, executeQuery, executeUpdate) are also defined in Relate.
WARNING: Because Relate uses curly braces as parameter delimiters, and to avoid additional overhead in query parsing, query strings containing curly braces will not work. However, curly braces can be used in values inserted in the on method. For example,
SQL("""
UPDATE pack
SET items= "[{\"name\" : \"Pokeball\", \"quantity\" : 2}]"
""")
will result in errors, but
SQL("""
UPDATE pack
SET items={value}
""").on { implicit query =>
string("value", "[{\"name\" : \"Pokeball\", \"quantity\" : 2}]")
}
would be just fine.