|
|
While transactions are frequently used to provide atomicity to multiple database operations, it is sometimes necessary to perform a single database operation under the control of a transaction. Rather than force you to obtain a transaction, perform the single write operation, and then either commit or abort the transaction, you can automatically group this sequence of events using auto commit.
To use auto commit:
Open your environment and your databases so that they support transactions. See Enabling Transactions for details.
Do not provide a transactional handle to the method that is performing the database write operation.
Note that auto commit is not available for cursors. You must always open your cursor using a transaction if you want the cursor's operations to be transactional protected. See Transactional Cursors for details on using transactional cursors.
For example, the following uses auto commit to perform the database write operation:
package db.txn; import com.sleepycat.db.Database; import com.sleepycat.db.DatabaseConfig; import com.sleepycat.db.DatabaseEntry; import com.sleepycat.db.DatabaseException; import com.sleepycat.db.Environment; import com.sleepycat.db.EnvironmentConfig; import java.io.File; ... Database myDatabase = null; Environment myEnv = null; try { EnvironmentConfig myEnvConfig = new EnvironmentConfig(); myEnvConfig.setInitializeCache(true); myEnvConfig.setInitializeLocking(true); myEnvConfig.setInitializeLogging(true); myEnvConfig.setTransactional(true); myEnv = new Environment(new File("/my/env/home"), myEnvConfig); // Open the database. DatabaseConfig dbConfig = new DatabaseConfig(); dbConfig.setTransactional(true); dbConfig.setType(DatabaseType.BTREE); myDatabase = myEnv.openDatabase(null, // txn handle "sampleDatabase", // db file name null, // db name dbConfig); String keyString = "thekey"; String dataString = "thedata"; DatabaseEntry key = new DatabaseEntry(keyString.getBytes("UTF-8")); DatabaseEntry data = new DatabaseEntry(dataString.getBytes("UTF-8")); // Perform the write. Because the database was opened to // support transactions, this write is performed using auto commit. myDatabase.put(null, key, data); } catch (DatabaseException de) { // Exception handling goes here }