This is how you fetch text from a SQL table with jcabi-jdbc:
Simple and straight forward, isn't it? The library simplifies interaction with relational databases via JDBC, avoiding the need to use ORM.
jcabi-jdbc is a lightweight wrapper of JDBC. It is very convenient to use when you don't need a full-scale ORM (like Hibernate), but want just to select, insert, or update a few rows in a relational database.
Every instance of
JdbcSession is a "transaction" in a database. You start it by instantiating the class with a single parameter—data source.
You can obtain the data source from your connection pool. There are many implementations of connection pools. I would recommend that you use BoneCP. Below is an example of how you would connect to PostgreSQL:
Be sure to pay attention to the
@Cacheable annotation. This post explains how it can help you to cache Java method results for some time. Setting the
forever attribute to
true means that we don't want this method to be called more than once. Instead, we want the connection pool to be created just once, and every second call should return its existing instance (kind of like a Singleton pattern).
JdbcSession closes the JDBC connection right after the first select/update/insert operation. Simply put, it is designed to be used mainly for single atomic transactions. However, it is possible to leave the connection open and continue, for example:
In this example we're executing three SQL statements one by one, leaving connection (and transaction) open until
commit() is called.