File: envcreate.html

package info (click to toggle)
db5.3 5.3.28%2Bdfsg1-0.5
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 158,360 kB
  • sloc: ansic: 448,411; java: 111,824; tcl: 80,544; sh: 44,326; cs: 33,697; cpp: 21,604; perl: 14,557; xml: 10,799; makefile: 4,077; yacc: 1,003; awk: 965; sql: 801; erlang: 342; python: 216; php: 24; asm: 14
file content (172 lines) | stat: -rw-r--r-- 8,180 bytes parent folder | download | duplicates (8)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
<?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>DbEnv</title>
    <link rel="stylesheet" href="apiReference.css" type="text/css" />
    <meta name="generator" content="DocBook XSL Stylesheets V1.73.2" />
    <link rel="start" href="index.html" title="Berkeley DB C++ API Reference" />
    <link rel="up" href="env.html" title="Chapter 5.  The DbEnv Handle" />
    <link rel="prev" href="envclose.html" title="DbEnv::close()" />
    <link rel="next" href="envdbbackup.html" title="DbEnv::dbbackup()" />
  </head>
  <body>
    <div xmlns="" class="navheader">
      <div class="libver">
        <p>Library Version 11.2.5.3</p>
      </div>
      <table width="100%" summary="Navigation header">
        <tr>
          <th colspan="3" align="center">DbEnv</th>
        </tr>
        <tr>
          <td width="20%" align="left"><a accesskey="p" href="envclose.html">Prev</a> </td>
          <th width="60%" align="center">Chapter 5. 
                The DbEnv Handle
        </th>
          <td width="20%" align="right"> <a accesskey="n" href="envdbbackup.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="envcreate"></a>DbEnv</h2>
          </div>
        </div>
      </div>
      <pre class="programlisting">#include &lt;db_cxx.h&gt;

class DbEnv { 
public: 
        DbEnv(u_int32 flags); 
        ~DbEnv();

        DB_ENV *DbEnv::get_DB_ENV(); 
        const DB_ENV *DbEnv::get_const_DB_ENV() const; 
        static DbEnv *DbEnv::get_DbEnv(DB_ENV *dbenv); 
        static const DbEnv *DbEnv::get_const_DbEnv(const DB_ENV *dbenv); 
        ... 
}; </pre>
      <p>
        The <code class="classname">DbEnv</code> object is the handle for a Berkeley DB environment — 
        a collection including support for some or all of caching, locking, logging and transaction subsystems, as well as
        databases and log files. Methods of the <code class="classname">DbEnv</code> handle are used to configure the environment
        as well as to operate on subsystems and databases in the environment.
    </p>
      <p>
        <code class="classname">DbEnv</code> handles are free-threaded if the 
        <a class="link" href="envopen.html#envopen_DB_THREAD">DB_THREAD</a> flag is specified to the
        <a class="xref" href="envopen.html" title="DbEnv::open()">DbEnv::open()</a> method when the environment is opened.
        The <code class="classname">DbEnv</code> handle should not be closed while any other handle
        remains open that is using it as a reference (for example, 
        <a class="link" href="db.html" title="Chapter 2.  The Db Handle">Db</a> or <a class="link" href="txn.html" title="Chapter 13.  The DbTxn Handle">DbTxn</a>). 
        Once either the
        <a class="xref" href="envclose.html" title="DbEnv::close()">DbEnv::close()</a> or 
        <a class="xref" href="envremove.html" title="DbEnv::remove()">DbEnv::remove()</a> 
        methods are called, the handle may not be accessed again, regardless of the method's return.
    </p>
      <p>
        The constructor creates the <code class="classname">DbEnv</code> object. 
        The constructor allocates memory internally; calling the 
        <a class="xref" href="envclose.html" title="DbEnv::close()">DbEnv::close()</a> or 
        <a class="xref" href="envremove.html" title="DbEnv::remove()">DbEnv::remove()</a> 
         methods will free that memory.
    </p>
      <p>
            Before the handle may be used, you must open it using the 
            <a class="xref" href="envopen.html" title="DbEnv::open()">DbEnv::open()</a>
            method.
    </p>
      <p>
            The <span class="bold"><strong>flags</strong></span> parameter must be set to 0.
    </p>
      <div class="itemizedlist">
        <ul type="disc">
          <li>
            <p><a id="env_DB_CXX_NO_EXCEPTIONS"></a>
                        <code class="literal">DB_CXX_NO_EXCEPTIONS</code>
                    </p>
            <p>
                            The Berkeley DB C++ API supports two different error behaviors. By default, whenever an error
                            occurs, an exception is thrown that encapsulates the error information. This
                            generally allows for cleaner logic for transaction processing because a try block can
                            surround a single transaction. However, if
                            <code class="literal">DB_CXX_NO_EXCEPTIONS</code> is specified, exceptions
                            are not thrown; instead, each individual function returns an error code.
                    </p>
          </li>
        </ul>
      </div>
      <p>
        Each <code class="classname">DbEnv</code> object has an associated <code class="literal">DB_ENV</code>
        structure, which is used by the underlying implementation of Berkeley DB and its C-language
        API. The <code class="methodname">DbEnv::get_DB_ENV()</code> method returns a pointer to this
        struct. Given a <code class="literal">const DbEnv</code> object,
        <code class="methodname">DbEnv::get_const_DB_ENV()</code> returns a const pointer to the same
        struct.
    </p>
      <p>
        Given a <code class="literal">DB_ENV</code> struct, the <code class="methodname">DbEnv::get_DbEnv()</code>
        method returns the corresponding <code class="classname">DbEnv</code> object,
        if there is one. If the <code class="literal">DB_ENV</code> struct was not associated with a
        <code class="classname">DbEnv</code> (that is, it was not
        returned from a call to <code class="methodname">DbEnv::get_DB_ENV()</code>), then the result of
        <code class="methodname">DbEnv::get_DbEnv()</code> is
        undefined. Given a <code class="literal">const DB_ENV</code> struct,
        <code class="methodname">DbEnv::get_const_Db_Env()</code> returns the associated 
        <code class="literal">const DbEnv</code> object, if there is one.
    </p>
      <p>
        These methods may be useful for Berkeley DB applications including both C and C++ language
        software. It should not be necessary to use these calls in a purely C++ application.
    </p>
      <div class="sect2" lang="en" xml:lang="en">
        <div class="titlepage">
          <div>
            <div>
              <h3 class="title"><a id="idp6652256"></a>Class</h3>
            </div>
          </div>
        </div>
        <p>
                     <a class="link" href="env.html" title="Chapter 5.  The DbEnv Handle">DbEnv</a>
            </p>
      </div>
      <div class="sect2" lang="en" xml:lang="en">
        <div class="titlepage">
          <div>
            <div>
              <h3 class="title"><a id="idp6623920"></a>See Also</h3>
            </div>
          </div>
        </div>
        <p>
                     <a class="xref" href="env.html#envlist" title="Database Environments and Related Methods">Database Environments and Related Methods</a> 
                </p>
      </div>
    </div>
    <div class="navfooter">
      <hr />
      <table width="100%" summary="Navigation footer">
        <tr>
          <td width="40%" align="left"><a accesskey="p" href="envclose.html">Prev</a> </td>
          <td width="20%" align="center">
            <a accesskey="u" href="env.html">Up</a>
          </td>
          <td width="40%" align="right"> <a accesskey="n" href="envdbbackup.html">Next</a></td>
        </tr>
        <tr>
          <td width="40%" align="left" valign="top">DbEnv::close() </td>
          <td width="20%" align="center">
            <a accesskey="h" href="index.html">Home</a>
          </td>
          <td width="40%" align="right" valign="top"> DbEnv::dbbackup()</td>
        </tr>
      </table>
    </div>
  </body>
</html>