mirror of
https://github.com/berkeleydb/je.git
synced 2024-11-15 01:46:24 +00:00
156 lines
5.6 KiB
HTML
156 lines
5.6 KiB
HTML
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
||
<html xmlns="http://www.w3.org/1999/xhtml">
|
||
<head>
|
||
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
|
||
<title>MyDbEnv</title>
|
||
<link rel="stylesheet" href="gettingStarted.css" type="text/css" />
|
||
<meta name="generator" content="DocBook XSL Stylesheets V1.73.2" />
|
||
<link rel="start" href="index.html" title="Getting Started with Berkeley DB Java Edition" />
|
||
<link rel="up" href="dpl_example.html" title="Chapter 6. A DPL Example" />
|
||
<link rel="prev" href="inventoryclass.html" title="Inventory.java" />
|
||
<link rel="next" href="dataaccessorclass.html" title="DataAccessor.java" />
|
||
</head>
|
||
<body>
|
||
<div xmlns="" class="navheader">
|
||
<div class="libver">
|
||
<p>Library Version 12.2.7.5</p>
|
||
</div>
|
||
<table width="100%" summary="Navigation header">
|
||
<tr>
|
||
<th colspan="3" align="center">MyDbEnv</th>
|
||
</tr>
|
||
<tr>
|
||
<td width="20%" align="left"><a accesskey="p" href="inventoryclass.html">Prev</a> </td>
|
||
<th width="60%" align="center">Chapter 6. A DPL Example</th>
|
||
<td width="20%" align="right"> <a accesskey="n" href="dataaccessorclass.html">Next</a></td>
|
||
</tr>
|
||
</table>
|
||
<hr />
|
||
</div>
|
||
<div class="sect1" lang="en" xml:lang="en">
|
||
<div class="titlepage">
|
||
<div>
|
||
<div>
|
||
<h2 class="title" style="clear: both"><a id="mydbenv-persist"></a>MyDbEnv</h2>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
<p>
|
||
The applications that we are building for our example both
|
||
must open and close environments and entity stores. One
|
||
of our applications is writing to the entity store, so this
|
||
application needs to open the store as read-write. It also
|
||
wants to be able to create the store if it does not exist.
|
||
</p>
|
||
<p>
|
||
Our second application only reads from the store. In this
|
||
case, the store should be opened as read-only.
|
||
</p>
|
||
<p>
|
||
We perform these activities by creating a single class that
|
||
is responsible for opening and closing our store and
|
||
environment. This class is shared by both our applications.
|
||
To use it, callers need to only provide the path to the
|
||
environment home directory, and to indicate whether the
|
||
object is meant to be read-only. The class implementation
|
||
is as follows:
|
||
</p>
|
||
<pre class="programlisting">package persist.gettingStarted;
|
||
|
||
import java.io.File;
|
||
|
||
import com.sleepycat.je.DatabaseException;
|
||
import com.sleepycat.je.Environment;
|
||
import com.sleepycat.je.EnvironmentConfig;
|
||
|
||
import com.sleepycat.persist.EntityStore;
|
||
import com.sleepycat.persist.StoreConfig;
|
||
|
||
public class MyDbEnv {
|
||
|
||
private Environment myEnv;
|
||
private EntityStore store;
|
||
|
||
// Our constructor does nothing
|
||
public MyDbEnv() {}
|
||
|
||
// The setup() method opens the environment and store
|
||
// for us.
|
||
public void setup(File envHome, boolean readOnly)
|
||
throws DatabaseException {
|
||
|
||
EnvironmentConfig myEnvConfig = new EnvironmentConfig();
|
||
StoreConfig storeConfig = new StoreConfig();
|
||
|
||
myEnvConfig.setReadOnly(readOnly);
|
||
storeConfig.setReadOnly(readOnly);
|
||
|
||
// If the environment is opened for write, then we want to be
|
||
// able to create the environment and entity store if
|
||
// they do not exist.
|
||
myEnvConfig.setAllowCreate(!readOnly);
|
||
storeConfig.setAllowCreate(!readOnly);
|
||
|
||
// Open the environment and entity store
|
||
myEnv = new Environment(envHome, myEnvConfig);
|
||
store = new EntityStore(myEnv, "EntityStore", storeConfig);
|
||
|
||
}
|
||
|
||
// Return a handle to the entity store
|
||
public EntityStore getEntityStore() {
|
||
return store;
|
||
}
|
||
|
||
// Return a handle to the environment
|
||
public Environment getEnv() {
|
||
return myEnv;
|
||
}
|
||
|
||
// Close the store and environment.
|
||
public void close() {
|
||
if (store != null) {
|
||
try {
|
||
store.close();
|
||
} catch(DatabaseException dbe) {
|
||
System.err.println("Error closing store: " +
|
||
dbe.toString());
|
||
System.exit(-1);
|
||
}
|
||
}
|
||
|
||
if (myEnv != null) {
|
||
try {
|
||
// Finally, close the environment.
|
||
myEnv.close();
|
||
} catch(DatabaseException dbe) {
|
||
System.err.println("Error closing MyDbEnv: " +
|
||
dbe.toString());
|
||
System.exit(-1);
|
||
}
|
||
}
|
||
}
|
||
} </pre>
|
||
</div>
|
||
<div class="navfooter">
|
||
<hr />
|
||
<table width="100%" summary="Navigation footer">
|
||
<tr>
|
||
<td width="40%" align="left"><a accesskey="p" href="inventoryclass.html">Prev</a> </td>
|
||
<td width="20%" align="center">
|
||
<a accesskey="u" href="dpl_example.html">Up</a>
|
||
</td>
|
||
<td width="40%" align="right"> <a accesskey="n" href="dataaccessorclass.html">Next</a></td>
|
||
</tr>
|
||
<tr>
|
||
<td width="40%" align="left" valign="top">Inventory.java </td>
|
||
<td width="20%" align="center">
|
||
<a accesskey="h" href="index.html">Home</a>
|
||
</td>
|
||
<td width="40%" align="right" valign="top"> DataAccessor.java</td>
|
||
</tr>
|
||
</table>
|
||
</div>
|
||
</body>
|
||
</html>
|