<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
 xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
 xmlns:dc="http://purl.org/dc/elements/1.1/"
 xmlns:content="http://purl.org/rss/1.0/modules/content/"
 xmlns:atom="http://www.w3.org/2005/Atom"
>
	<channel>
		<copyright>Copyright 1998 - 2026 DPG Media B.V.</copyright>
		<pubDate>Mon, 11 May 2026 04:42:57 GMT</pubDate>
		<lastBuildDate>Mon, 11 May 2026 04:42:57 GMT</lastBuildDate>
		<description>GoT - list_messages</description>
		<image>
			<link>https://gathering.tweakers.net/</link>
			<title>Gathering of Tweakers</title>
			<url>https://tweakers.net/g/if/logo.gif</url>
		</image>
		<language>nl-nl</language>
		<link>https://gathering.tweakers.net/rss/list_messages/1293459</link>
		<atom:link href="https://gathering.tweakers.net/rss/list_messages/1293459" rel="self" type="application/rss+xml" />
		<title>[php smarty] query vraag - Softwareontwikkeling - GoT</title>
		<webMaster>gathering@tweakers.net (Administrator)</webMaster>
		<item>
			<title>Verwijderd</title>
			<link>https://gathering.tweakers.net/forum/list_message/30107197#30107197</link>
			<description>laatste deel:

PHP: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
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
    // }}}
    // {{{ fetchRow()
    /**
     * Fetch a row of data and return it by reference into an array
     *
     * The type of array returned can be controlled either by setting this
     * method&#039;s &lt;var&gt;$fetchmode&lt;/var&gt; parameter or by changing the default
     * fetch mode setFetchMode() before calling this method.
     *
     * There are two options for standardizing the information returned
     * from databases, ensuring their values are consistent when changing
     * DBMS&#039;s.  These portability options can be turned on when creating a
     * new DB object or by using setOption().
     *
     *   + &lt;var&gt;DB_PORTABILITY_LOWERCASE&lt;/var&gt;
     *     convert names of fields to lower case
     *
     *   + &lt;var&gt;DB_PORTABILITY_RTRIM&lt;/var&gt;
     *     right trim the data
     *
     * @param int $fetchmode  the constant indicating how to format the data
     * @param int $rownum     the row number to fetch (index starts at 0)
     *
     * @return mixed  an array or object containing the row&#039;s data,
     *                 NULL when the end of the result set is reached
     *                 or a DB_Error object on failure.
     *
     * @see DB_common::setOption(), DB_common::setFetchMode()
     */
    function &amp;fetchRow($fetchmode = DB_FETCHMODE_DEFAULT, $rownum = null)
    {
        if ($fetchmode === DB_FETCHMODE_DEFAULT) {
            $fetchmode = $this-&gt;fetchmode;
        }
        if ($fetchmode === DB_FETCHMODE_OBJECT) {
            $fetchmode = DB_FETCHMODE_ASSOC;
            $object_class = $this-&gt;fetchmode_object_class;
        }
        if ($this-&gt;limit_from !== null) {
            if ($this-&gt;row_counter === null) {
                $this-&gt;row_counter = $this-&gt;limit_from;
                // Skip rows
                if ($this-&gt;dbh-&gt;features[&#039;limit&#039;] === false) {
                    $i = 0;
                    while ($i++ &lt; $this-&gt;limit_from) {
                        $this-&gt;dbh-&gt;fetchInto($this-&gt;result, $arr, $fetchmode);
                    }
                }
            }
            if ($this-&gt;row_counter &gt;= ($this-&gt;limit_from + $this-&gt;limit_count))
            {
                if ($this-&gt;autofree) {
                    $this-&gt;free();
                }
                $tmp = null;
                return $tmp;
            }
            if ($this-&gt;dbh-&gt;features[&#039;limit&#039;] === &#039;emulate&#039;) {
                $rownum = $this-&gt;row_counter;
            }
            $this-&gt;row_counter++;
        }
        $res = $this-&gt;dbh-&gt;fetchInto($this-&gt;result, $arr, $fetchmode, $rownum);
        if ($res === DB_OK) {
            if (isset($object_class)) {
                // The default mode is specified in the
                // DB_common::fetchmode_object_class property
                if ($object_class == &#039;stdClass&#039;) {
                    $arr = (object) $arr;
                } else {
                    $arr = &amp;new $object_class($arr);
                }
            }
            return $arr;
        }
        if ($res == null &amp;&amp; $this-&gt;autofree) {
            $this-&gt;free();
        }
        return $res;
    }

    // }}}
    // {{{ fetchInto()

    /**
     * Fetch a row of data into an array which is passed by reference
     *
     * The type of array returned can be controlled either by setting this
     * method&#039;s &lt;var&gt;$fetchmode&lt;/var&gt; parameter or by changing the default
     * fetch mode setFetchMode() before calling this method.
     *
     * There are two options for standardizing the information returned
     * from databases, ensuring their values are consistent when changing
     * DBMS&#039;s.  These portability options can be turned on when creating a
     * new DB object or by using setOption().
     *
     *   + &lt;var&gt;DB_PORTABILITY_LOWERCASE&lt;/var&gt;
     *     convert names of fields to lower case
     *
     *   + &lt;var&gt;DB_PORTABILITY_RTRIM&lt;/var&gt;
     *     right trim the data
     *
     * @param array &amp;$arr       the variable where the data should be placed
     * @param int   $fetchmode  the constant indicating how to format the data
     * @param int   $rownum     the row number to fetch (index starts at 0)
     *
     * @return mixed  DB_OK if a row is processed, NULL when the end of the
     *                 result set is reached or a DB_Error object on failure
     *
     * @see DB_common::setOption(), DB_common::setFetchMode()
     */
    function fetchInto(&amp;$arr, $fetchmode = DB_FETCHMODE_DEFAULT, $rownum = null)
    {
        if ($fetchmode === DB_FETCHMODE_DEFAULT) {
            $fetchmode = $this-&gt;fetchmode;
        }
        if ($fetchmode === DB_FETCHMODE_OBJECT) {
            $fetchmode = DB_FETCHMODE_ASSOC;
            $object_class = $this-&gt;fetchmode_object_class;
        }
        if ($this-&gt;limit_from !== null) {
            if ($this-&gt;row_counter === null) {
                $this-&gt;row_counter = $this-&gt;limit_from;
                // Skip rows
                if ($this-&gt;dbh-&gt;features[&#039;limit&#039;] === false) {
                    $i = 0;
                    while ($i++ &lt; $this-&gt;limit_from) {
                        $this-&gt;dbh-&gt;fetchInto($this-&gt;result, $arr, $fetchmode);
                    }
                }
            }
            if ($this-&gt;row_counter &gt;= (
                    $this-&gt;limit_from + $this-&gt;limit_count))
            {
                if ($this-&gt;autofree) {
                    $this-&gt;free();
                }
                return null;
            }
            if ($this-&gt;dbh-&gt;features[&#039;limit&#039;] === &#039;emulate&#039;) {
                $rownum = $this-&gt;row_counter;
            }

            $this-&gt;row_counter++;
        }
        $res = $this-&gt;dbh-&gt;fetchInto($this-&gt;result, $arr, $fetchmode, $rownum);
        if ($res === DB_OK) {
            if (isset($object_class)) {
                // default mode specified in the
                // DB_common::fetchmode_object_class property
                if ($object_class == &#039;stdClass&#039;) {
                    $arr = (object) $arr;
                } else {
                    $arr = new $object_class($arr);
                }
            }
            return DB_OK;
        }
        if ($res == null &amp;&amp; $this-&gt;autofree) {
            $this-&gt;free();
        }
        return $res;
    }

    // }}}
    // {{{ numCols()

    /**
     * Get the the number of columns in a result set
     *
     * @return int  the number of columns.  A DB_Error object on failure.
     */
    function numCols()
    {
        return $this-&gt;dbh-&gt;numCols($this-&gt;result);
    }

    // }}}
    // {{{ numRows()

    /**
     * Get the number of rows in a result set
     *
     * @return int  the number of rows.  A DB_Error object on failure.
     */
    function numRows()
    {
        if ($this-&gt;dbh-&gt;features[&#039;numrows&#039;] === &#039;emulate&#039;
            &amp;&amp; $this-&gt;dbh-&gt;options[&#039;portability&#039;] &amp; DB_PORTABILITY_NUMROWS)
        {
            if ($this-&gt;dbh-&gt;features[&#039;prepare&#039;]) {
                $res = $this-&gt;dbh-&gt;query($this-&gt;query, $this-&gt;parameters);
            } else {
                $res = $this-&gt;dbh-&gt;query($this-&gt;query);
            }
            if (DB::isError($res)) {
                return $res;
            }
            $i = 0;
            while ($res-&gt;fetchInto($tmp, DB_FETCHMODE_ORDERED)) {
                $i++;
            }
            return $i;
        } else {
            return $this-&gt;dbh-&gt;numRows($this-&gt;result);
        }
    }

    // }}}
    // {{{ nextResult()
    /**
     * Get the next result if a batch of queries was executed
     *
     * @return bool  true if a new result is available or false if not
     */
    function nextResult()
    {
        return $this-&gt;dbh-&gt;nextResult($this-&gt;result);
    }

    // }}}
    // {{{ free()

    /**
     * Frees the resources allocated for this result set
     *
     * @return bool  true on success.  A DB_Error object on failure.
     */
    function free()
    {
        $err = $this-&gt;dbh-&gt;freeResult($this-&gt;result);
        if (DB::isError($err)) {
            return $err;
        }
        $this-&gt;result = false;
        $this-&gt;statement = false;
        return true;
    }

    // }}}
    // {{{ tableInfo()

    /**
     * @see DB_common::tableInfo()
     * @deprecated Method deprecated some time before Release 1.2
     */
    function tableInfo($mode = null)
    {
        if (is_string($mode)) {
            return $this-&gt;dbh-&gt;raiseError(DB_ERROR_NEED_MORE_DATA);
        }
        return $this-&gt;dbh-&gt;tableInfo($this, $mode);
    }

    // }}}
    // {{{ getQuery()

    /**
     * Determine the query string that created this result
     *
     * @return string  the query string
     *
     * @since Method available since Release 1.7.0
     */
    function getQuery()
    {
        return $this-&gt;query;
    }

    // }}}
    // {{{ getRowCounter()
    /**
     * Tells which row number is currently being processed
     *
     * @return integer  the current row being looked at.  Starts at 1.
     */
    function getRowCounter()
    {
        return $this-&gt;row_counter;
    }

    // }}}
}

// }}}
// {{{ class DB_row

/**
 * PEAR DB Row Object
 *
 * The object contains a row of data from a result set.  Each column&#039;s data
 * is placed in a property named for the column.
 *
 * @category   Database
 * @package    DB
 * @author     Stig Bakken &lt;ssb@php.net&gt;
 * @copyright  1997-2005 The PHP Group
 * @license    http://www.php.net/license/3_0.txt  PHP License 3.0
 * @version    Release: 1.7.6
 * @link       http://pear.php.net/package/DB
 * @see        DB_common::setFetchMode()
 */
class DB_row
{
    // {{{ constructor

    /**
     * The constructor places a row&#039;s data into properties of this object
     *
     * @param array  the array containing the row&#039;s data
     *
     * @return void
     */
    function DB_row(&amp;$arr)
    {
        foreach ($arr as $key =&gt; $value) {
            $this-&gt;$key = &amp;$arr[$key];
        }
    }

    // }}}
}

// }}}

/*
 * Local variables:
 * tab-width: 4
 * c-basic-offset: 4
 * End:
 */

?&gt;

Hoop dat je er iets aan hebt maar daar lijkt mij niet de fout te zitten dit omdat PEAR DB best veel wordt gebruikt en dit op zich niet zoiets heel geks is lijkt mij.</description>
			<content:encoded><![CDATA[laatste deel:<br>
<br>
<div class="code">PHP:<br><table class="phphighlight"><tr><td class="phphighlightline"><pre>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
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
</pre></td><td class="phphighlightcode"><div><pre><span class="code_x">    // }}}</span>
<span class="code_x">    // {{{ fetchRow()</span>
<span class="code_x">    /**</span>
<span class="code_x">     * Fetch a row of data and return it by reference into an array</span>
<span class="code_x">     *</span>
<span class="code_x">     * The type of array returned can be controlled either by setting this</span>
<span class="code_x">     * method&#39;s &lt;var&gt;$fetchmode&lt;/var&gt; parameter or by changing the default</span>
<span class="code_x">     * fetch mode setFetchMode() before calling this method.</span>
<span class="code_x">     *</span>
<span class="code_x">     * There are two options for standardizing the information returned</span>
<span class="code_x">     * from databases, ensuring their values are consistent when changing</span>
<span class="code_x">     * DBMS&#39;s.  These portability options can be turned on when creating a</span>
<span class="code_x">     * new DB object or by using setOption().</span>
<span class="code_x">     *</span>
<span class="code_x">     *   + &lt;var&gt;DB_PORTABILITY_LOWERCASE&lt;/var&gt;</span>
<span class="code_x">     *     convert names of fields to lower case</span>
<span class="code_x">     *</span>
<span class="code_x">     *   + &lt;var&gt;DB_PORTABILITY_RTRIM&lt;/var&gt;</span>
<span class="code_x">     *     right trim the data</span>
<span class="code_x">     *</span>
<span class="code_x">     * @param int $fetchmode  the constant indicating how to format the data</span>
<span class="code_x">     * @param int $rownum     the row number to fetch (index starts at 0)</span>
<span class="code_x">     *</span>
<span class="code_x">     * @return mixed  an array or object containing the row&#39;s data,</span>
<span class="code_x">     *                 NULL when the end of the result set is reached</span>
<span class="code_x">     *                 or a DB_Error object on failure.</span>
<span class="code_x">     *</span>
<span class="code_x">     * @see DB_common::setOption(), DB_common::setFetchMode()</span>
<span class="code_x">     */</span>
<span class="code_x">    function &amp;fetchRow($fetchmode = DB_FETCHMODE_DEFAULT, $rownum = null)</span>
<span class="code_x">    {</span>
<span class="code_x">        if ($fetchmode === DB_FETCHMODE_DEFAULT) {</span>
<span class="code_x">            $fetchmode = $this-&gt;fetchmode;</span>
<span class="code_x">        }</span>
<span class="code_x">        if ($fetchmode === DB_FETCHMODE_OBJECT) {</span>
<span class="code_x">            $fetchmode = DB_FETCHMODE_ASSOC;</span>
<span class="code_x">            $object_class = $this-&gt;fetchmode_object_class;</span>
<span class="code_x">        }</span>
<span class="code_x">        if ($this-&gt;limit_from !== null) {</span>
<span class="code_x">            if ($this-&gt;row_counter === null) {</span>
<span class="code_x">                $this-&gt;row_counter = $this-&gt;limit_from;</span>
<span class="code_x">                // Skip rows</span>
<span class="code_x">                if ($this-&gt;dbh-&gt;features[&#39;limit&#39;] === false) {</span>
<span class="code_x">                    $i = 0;</span>
<span class="code_x">                    while ($i++ &lt; $this-&gt;limit_from) {</span>
<span class="code_x">                        $this-&gt;dbh-&gt;fetchInto($this-&gt;result, $arr, $fetchmode);</span>
<span class="code_x">                    }</span>
<span class="code_x">                }</span>
<span class="code_x">            }</span>
<span class="code_x">            if ($this-&gt;row_counter &gt;= ($this-&gt;limit_from + $this-&gt;limit_count))</span>
<span class="code_x">            {</span>
<span class="code_x">                if ($this-&gt;autofree) {</span>
<span class="code_x">                    $this-&gt;free();</span>
<span class="code_x">                }</span>
<span class="code_x">                $tmp = null;</span>
<span class="code_x">                return $tmp;</span>
<span class="code_x">            }</span>
<span class="code_x">            if ($this-&gt;dbh-&gt;features[&#39;limit&#39;] === &#39;emulate&#39;) {</span>
<span class="code_x">                $rownum = $this-&gt;row_counter;</span>
<span class="code_x">            }</span>
<span class="code_x">            $this-&gt;row_counter++;</span>
<span class="code_x">        }</span>
<span class="code_x">        $res = $this-&gt;dbh-&gt;fetchInto($this-&gt;result, $arr, $fetchmode, $rownum);</span>
<span class="code_x">        if ($res === DB_OK) {</span>
<span class="code_x">            if (isset($object_class)) {</span>
<span class="code_x">                // The default mode is specified in the</span>
<span class="code_x">                // DB_common::fetchmode_object_class property</span>
<span class="code_x">                if ($object_class == &#39;stdClass&#39;) {</span>
<span class="code_x">                    $arr = (object) $arr;</span>
<span class="code_x">                } else {</span>
<span class="code_x">                    $arr = &amp;new $object_class($arr);</span>
<span class="code_x">                }</span>
<span class="code_x">            }</span>
<span class="code_x">            return $arr;</span>
<span class="code_x">        }</span>
<span class="code_x">        if ($res == null &amp;&amp; $this-&gt;autofree) {</span>
<span class="code_x">            $this-&gt;free();</span>
<span class="code_x">        }</span>
<span class="code_x">        return $res;</span>
<span class="code_x">    }</span>

<span class="code_x">    // }}}</span>
<span class="code_x">    // {{{ fetchInto()</span>

<span class="code_x">    /**</span>
<span class="code_x">     * Fetch a row of data into an array which is passed by reference</span>
<span class="code_x">     *</span>
<span class="code_x">     * The type of array returned can be controlled either by setting this</span>
<span class="code_x">     * method&#39;s &lt;var&gt;$fetchmode&lt;/var&gt; parameter or by changing the default</span>
<span class="code_x">     * fetch mode setFetchMode() before calling this method.</span>
<span class="code_x">     *</span>
<span class="code_x">     * There are two options for standardizing the information returned</span>
<span class="code_x">     * from databases, ensuring their values are consistent when changing</span>
<span class="code_x">     * DBMS&#39;s.  These portability options can be turned on when creating a</span>
<span class="code_x">     * new DB object or by using setOption().</span>
<span class="code_x">     *</span>
<span class="code_x">     *   + &lt;var&gt;DB_PORTABILITY_LOWERCASE&lt;/var&gt;</span>
<span class="code_x">     *     convert names of fields to lower case</span>
<span class="code_x">     *</span>
<span class="code_x">     *   + &lt;var&gt;DB_PORTABILITY_RTRIM&lt;/var&gt;</span>
<span class="code_x">     *     right trim the data</span>
<span class="code_x">     *</span>
<span class="code_x">     * @param array &amp;$arr       the variable where the data should be placed</span>
<span class="code_x">     * @param int   $fetchmode  the constant indicating how to format the data</span>
<span class="code_x">     * @param int   $rownum     the row number to fetch (index starts at 0)</span>
<span class="code_x">     *</span>
<span class="code_x">     * @return mixed  DB_OK if a row is processed, NULL when the end of the</span>
<span class="code_x">     *                 result set is reached or a DB_Error object on failure</span>
<span class="code_x">     *</span>
<span class="code_x">     * @see DB_common::setOption(), DB_common::setFetchMode()</span>
<span class="code_x">     */</span>
<span class="code_x">    function fetchInto(&amp;$arr, $fetchmode = DB_FETCHMODE_DEFAULT, $rownum = null)</span>
<span class="code_x">    {</span>
<span class="code_x">        if ($fetchmode === DB_FETCHMODE_DEFAULT) {</span>
<span class="code_x">            $fetchmode = $this-&gt;fetchmode;</span>
<span class="code_x">        }</span>
<span class="code_x">        if ($fetchmode === DB_FETCHMODE_OBJECT) {</span>
<span class="code_x">            $fetchmode = DB_FETCHMODE_ASSOC;</span>
<span class="code_x">            $object_class = $this-&gt;fetchmode_object_class;</span>
<span class="code_x">        }</span>
<span class="code_x">        if ($this-&gt;limit_from !== null) {</span>
<span class="code_x">            if ($this-&gt;row_counter === null) {</span>
<span class="code_x">                $this-&gt;row_counter = $this-&gt;limit_from;</span>
<span class="code_x">                // Skip rows</span>
<span class="code_x">                if ($this-&gt;dbh-&gt;features[&#39;limit&#39;] === false) {</span>
<span class="code_x">                    $i = 0;</span>
<span class="code_x">                    while ($i++ &lt; $this-&gt;limit_from) {</span>
<span class="code_x">                        $this-&gt;dbh-&gt;fetchInto($this-&gt;result, $arr, $fetchmode);</span>
<span class="code_x">                    }</span>
<span class="code_x">                }</span>
<span class="code_x">            }</span>
<span class="code_x">            if ($this-&gt;row_counter &gt;= (</span>
<span class="code_x">                    $this-&gt;limit_from + $this-&gt;limit_count))</span>
<span class="code_x">            {</span>
<span class="code_x">                if ($this-&gt;autofree) {</span>
<span class="code_x">                    $this-&gt;free();</span>
<span class="code_x">                }</span>
<span class="code_x">                return null;</span>
<span class="code_x">            }</span>
<span class="code_x">            if ($this-&gt;dbh-&gt;features[&#39;limit&#39;] === &#39;emulate&#39;) {</span>
<span class="code_x">                $rownum = $this-&gt;row_counter;</span>
<span class="code_x">            }</span>

<span class="code_x">            $this-&gt;row_counter++;</span>
<span class="code_x">        }</span>
<span class="code_x">        $res = $this-&gt;dbh-&gt;fetchInto($this-&gt;result, $arr, $fetchmode, $rownum);</span>
<span class="code_x">        if ($res === DB_OK) {</span>
<span class="code_x">            if (isset($object_class)) {</span>
<span class="code_x">                // default mode specified in the</span>
<span class="code_x">                // DB_common::fetchmode_object_class property</span>
<span class="code_x">                if ($object_class == &#39;stdClass&#39;) {</span>
<span class="code_x">                    $arr = (object) $arr;</span>
<span class="code_x">                } else {</span>
<span class="code_x">                    $arr = new $object_class($arr);</span>
<span class="code_x">                }</span>
<span class="code_x">            }</span>
<span class="code_x">            return DB_OK;</span>
<span class="code_x">        }</span>
<span class="code_x">        if ($res == null &amp;&amp; $this-&gt;autofree) {</span>
<span class="code_x">            $this-&gt;free();</span>
<span class="code_x">        }</span>
<span class="code_x">        return $res;</span>
<span class="code_x">    }</span>

<span class="code_x">    // }}}</span>
<span class="code_x">    // {{{ numCols()</span>

<span class="code_x">    /**</span>
<span class="code_x">     * Get the the number of columns in a result set</span>
<span class="code_x">     *</span>
<span class="code_x">     * @return int  the number of columns.  A DB_Error object on failure.</span>
<span class="code_x">     */</span>
<span class="code_x">    function numCols()</span>
<span class="code_x">    {</span>
<span class="code_x">        return $this-&gt;dbh-&gt;numCols($this-&gt;result);</span>
<span class="code_x">    }</span>

<span class="code_x">    // }}}</span>
<span class="code_x">    // {{{ numRows()</span>

<span class="code_x">    /**</span>
<span class="code_x">     * Get the number of rows in a result set</span>
<span class="code_x">     *</span>
<span class="code_x">     * @return int  the number of rows.  A DB_Error object on failure.</span>
<span class="code_x">     */</span>
<span class="code_x">    function numRows()</span>
<span class="code_x">    {</span>
<span class="code_x">        if ($this-&gt;dbh-&gt;features[&#39;numrows&#39;] === &#39;emulate&#39;</span>
<span class="code_x">            &amp;&amp; $this-&gt;dbh-&gt;options[&#39;portability&#39;] &amp; DB_PORTABILITY_NUMROWS)</span>
<span class="code_x">        {</span>
<span class="code_x">            if ($this-&gt;dbh-&gt;features[&#39;prepare&#39;]) {</span>
<span class="code_x">                $res = $this-&gt;dbh-&gt;query($this-&gt;query, $this-&gt;parameters);</span>
<span class="code_x">            } else {</span>
<span class="code_x">                $res = $this-&gt;dbh-&gt;query($this-&gt;query);</span>
<span class="code_x">            }</span>
<span class="code_x">            if (DB::isError($res)) {</span>
<span class="code_x">                return $res;</span>
<span class="code_x">            }</span>
<span class="code_x">            $i = 0;</span>
<span class="code_x">            while ($res-&gt;fetchInto($tmp, DB_FETCHMODE_ORDERED)) {</span>
<span class="code_x">                $i++;</span>
<span class="code_x">            }</span>
<span class="code_x">            return $i;</span>
<span class="code_x">        } else {</span>
<span class="code_x">            return $this-&gt;dbh-&gt;numRows($this-&gt;result);</span>
<span class="code_x">        }</span>
<span class="code_x">    }</span>

<span class="code_x">    // }}}</span>
<span class="code_x">    // {{{ nextResult()</span>
<span class="code_x">    /**</span>
<span class="code_x">     * Get the next result if a batch of queries was executed</span>
<span class="code_x">     *</span>
<span class="code_x">     * @return bool  true if a new result is available or false if not</span>
<span class="code_x">     */</span>
<span class="code_x">    function nextResult()</span>
<span class="code_x">    {</span>
<span class="code_x">        return $this-&gt;dbh-&gt;nextResult($this-&gt;result);</span>
<span class="code_x">    }</span>

<span class="code_x">    // }}}</span>
<span class="code_x">    // {{{ free()</span>

<span class="code_x">    /**</span>
<span class="code_x">     * Frees the resources allocated for this result set</span>
<span class="code_x">     *</span>
<span class="code_x">     * @return bool  true on success.  A DB_Error object on failure.</span>
<span class="code_x">     */</span>
<span class="code_x">    function free()</span>
<span class="code_x">    {</span>
<span class="code_x">        $err = $this-&gt;dbh-&gt;freeResult($this-&gt;result);</span>
<span class="code_x">        if (DB::isError($err)) {</span>
<span class="code_x">            return $err;</span>
<span class="code_x">        }</span>
<span class="code_x">        $this-&gt;result = false;</span>
<span class="code_x">        $this-&gt;statement = false;</span>
<span class="code_x">        return true;</span>
<span class="code_x">    }</span>

<span class="code_x">    // }}}</span>
<span class="code_x">    // {{{ tableInfo()</span>

<span class="code_x">    /**</span>
<span class="code_x">     * @see DB_common::tableInfo()</span>
<span class="code_x">     * @deprecated Method deprecated some time before Release 1.2</span>
<span class="code_x">     */</span>
<span class="code_x">    function tableInfo($mode = null)</span>
<span class="code_x">    {</span>
<span class="code_x">        if (is_string($mode)) {</span>
<span class="code_x">            return $this-&gt;dbh-&gt;raiseError(DB_ERROR_NEED_MORE_DATA);</span>
<span class="code_x">        }</span>
<span class="code_x">        return $this-&gt;dbh-&gt;tableInfo($this, $mode);</span>
<span class="code_x">    }</span>

<span class="code_x">    // }}}</span>
<span class="code_x">    // {{{ getQuery()</span>

<span class="code_x">    /**</span>
<span class="code_x">     * Determine the query string that created this result</span>
<span class="code_x">     *</span>
<span class="code_x">     * @return string  the query string</span>
<span class="code_x">     *</span>
<span class="code_x">     * @since Method available since Release 1.7.0</span>
<span class="code_x">     */</span>
<span class="code_x">    function getQuery()</span>
<span class="code_x">    {</span>
<span class="code_x">        return $this-&gt;query;</span>
<span class="code_x">    }</span>

<span class="code_x">    // }}}</span>
<span class="code_x">    // {{{ getRowCounter()</span>
<span class="code_x">    /**</span>
<span class="code_x">     * Tells which row number is currently being processed</span>
<span class="code_x">     *</span>
<span class="code_x">     * @return integer  the current row being looked at.  Starts at 1.</span>
<span class="code_x">     */</span>
<span class="code_x">    function getRowCounter()</span>
<span class="code_x">    {</span>
<span class="code_x">        return $this-&gt;row_counter;</span>
<span class="code_x">    }</span>

<span class="code_x">    // }}}</span>
<span class="code_x">}</span>

<span class="code_x">// }}}</span>
<span class="code_x">// {{{ class DB_row</span>

<span class="code_x">/**</span>
<span class="code_x"> * PEAR DB Row Object</span>
<span class="code_x"> *</span>
<span class="code_x"> * The object contains a row of data from a result set.  Each column&#39;s data</span>
<span class="code_x"> * is placed in a property named for the column.</span>
<span class="code_x"> *</span>
<span class="code_x"> * @category   Database</span>
<span class="code_x"> * @package    DB</span>
<span class="code_x"> * @author     Stig Bakken &lt;ssb@php.net&gt;</span>
<span class="code_x"> * @copyright  1997-2005 The PHP Group</span>
<span class="code_x"> * @license    http://www.php.net/license/3_0.txt  PHP License 3.0</span>
<span class="code_x"> * @version    Release: 1.7.6</span>
<span class="code_x"> * @link       http://pear.php.net/package/DB</span>
<span class="code_x"> * @see        DB_common::setFetchMode()</span>
<span class="code_x"> */</span>
<span class="code_x">class DB_row</span>
<span class="code_x">{</span>
<span class="code_x">    // {{{ constructor</span>

<span class="code_x">    /**</span>
<span class="code_x">     * The constructor places a row&#39;s data into properties of this object</span>
<span class="code_x">     *</span>
<span class="code_x">     * @param array  the array containing the row&#39;s data</span>
<span class="code_x">     *</span>
<span class="code_x">     * @return void</span>
<span class="code_x">     */</span>
<span class="code_x">    function DB_row(&amp;$arr)</span>
<span class="code_x">    {</span>
<span class="code_x">        foreach ($arr as $key =&gt; $value) {</span>
<span class="code_x">            $this-&gt;$key = &amp;$arr[$key];</span>
<span class="code_x">        }</span>
<span class="code_x">    }</span>

<span class="code_x">    // }}}</span>
<span class="code_x">}</span>

<span class="code_x">// }}}</span>

<span class="code_x">/*</span>
<span class="code_x"> * Local variables:</span>
<span class="code_x"> * tab-width: 4</span>
<span class="code_x"> * c-basic-offset: 4</span>
<span class="code_x"> * End:</span>
<span class="code_x"> */</span>

<span class="code_x">?&gt;</span></pre></div></td></tr></table></div><br>
<br>
Hoop dat je er iets aan hebt maar daar lijkt mij niet de fout te zitten dit omdat PEAR DB best veel wordt gebruikt en dit op zich niet zoiets heel geks is lijkt mij.]]></content:encoded>
			<dc:creator>Verwijderd</dc:creator>
			<guid isPermaLink="false">https://gathering.tweakers.net/forum/list_message/30107197#30107197</guid>
			<pubDate>Wed, 21 May 2008 15:32:12 GMT</pubDate>
		</item>
		<item>
			<title>Verwijderd</title>
			<link>https://gathering.tweakers.net/forum/list_message/30107196#30107196</link>
			<description>deel2:
PHP: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
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
    /**
     * Return a textual error message for a DB error code
     *
     * @param integer $value  the DB error code
     *
     * @return string  the error message or false if the error code was
     *                  not recognized
     */
    function errorMessage($value)
    {
        static $errorMessages;
        if (!isset($errorMessages)) {
            $errorMessages = array(
                DB_ERROR                    =&gt; &#039;unknown error&#039;,
                DB_ERROR_ACCESS_VIOLATION   =&gt; &#039;insufficient permissions&#039;,
                DB_ERROR_ALREADY_EXISTS     =&gt; &#039;already exists&#039;,
                DB_ERROR_CANNOT_CREATE      =&gt; &#039;can not create&#039;,
                DB_ERROR_CANNOT_DROP        =&gt; &#039;can not drop&#039;,
                DB_ERROR_CONNECT_FAILED     =&gt; &#039;connect failed&#039;,
                DB_ERROR_CONSTRAINT         =&gt; &#039;constraint violation&#039;,
                DB_ERROR_CONSTRAINT_NOT_NULL=&gt; &#039;null value violates not-null constraint&#039;,
                DB_ERROR_DIVZERO            =&gt; &#039;division by zero&#039;,
                DB_ERROR_EXTENSION_NOT_FOUND=&gt; &#039;extension not found&#039;,
                DB_ERROR_INVALID            =&gt; &#039;invalid&#039;,
                DB_ERROR_INVALID_DATE       =&gt; &#039;invalid date or time&#039;,
                DB_ERROR_INVALID_DSN        =&gt; &#039;invalid DSN&#039;,
                DB_ERROR_INVALID_NUMBER     =&gt; &#039;invalid number&#039;,
                DB_ERROR_MISMATCH           =&gt; &#039;mismatch&#039;,
                DB_ERROR_NEED_MORE_DATA     =&gt; &#039;insufficient data supplied&#039;,
                DB_ERROR_NODBSELECTED       =&gt; &#039;no database selected&#039;,
                DB_ERROR_NOSUCHDB           =&gt; &#039;no such database&#039;,
                DB_ERROR_NOSUCHFIELD        =&gt; &#039;no such field&#039;,
                DB_ERROR_NOSUCHTABLE        =&gt; &#039;no such table&#039;,
                DB_ERROR_NOT_CAPABLE        =&gt; &#039;DB backend not capable&#039;,
                DB_ERROR_NOT_FOUND          =&gt; &#039;not found&#039;,
                DB_ERROR_NOT_LOCKED         =&gt; &#039;not locked&#039;,
                DB_ERROR_SYNTAX             =&gt; &#039;syntax error&#039;,
                DB_ERROR_UNSUPPORTED        =&gt; &#039;not supported&#039;,
                DB_ERROR_TRUNCATED          =&gt; &#039;truncated&#039;,
                DB_ERROR_VALUE_COUNT_ON_ROW =&gt; &#039;value count on row&#039;,
                DB_OK                       =&gt; &#039;no error&#039;,
            );
        }

        if (DB::isError($value)) {
            $value = $value-&gt;getCode();
        }

        return isset($errorMessages[$value]) ? $errorMessages[$value]
                     : $errorMessages[DB_ERROR];
    }

    // }}}
    // {{{ parseDSN()
    /**
     * Parse a data source name
     *
     * Additional keys can be added by appending a URI query string to the
     * end of the DSN.
     *
     * The format of the supplied DSN is in its fullest form:
     * &lt;code&gt;
     *  phptype(dbsyntax)://username:password@protocol+hostspec/database?option=8&amp;another=true
     * &lt;/code&gt;
     *
     * Most variations are allowed:
     * &lt;code&gt;
     *  phptype://username:password@protocol+hostspec:110//usr/db_file.db?mode=0644
     *  phptype://username:password@hostspec/database_name
     *  phptype://username:password@hostspec
     *  phptype://username@hostspec
     *  phptype://hostspec/database
     *  phptype://hostspec
     *  phptype(dbsyntax)
     *  phptype
     * &lt;/code&gt;
     *
     * @param string $dsn Data Source Name to be parsed
     *
     * @return array an associative array with the following keys:
     *  + phptype:  Database backend used in PHP (mysql, odbc etc.)
     *  + dbsyntax: Database used with regards to SQL syntax etc.
     *  + protocol: Communication protocol to use (tcp, unix etc.)
     *  + hostspec: Host specification (hostname[:port])
     *  + database: Database to use on the DBMS server
     *  + username: User name for login
     *  + password: Password for login
     */
    function parseDSN($dsn)
    {
        $parsed = array(
            &#039;phptype&#039;  =&gt; false,
            &#039;dbsyntax&#039; =&gt; false,
            &#039;username&#039; =&gt; false,
            &#039;password&#039; =&gt; false,
            &#039;protocol&#039; =&gt; false,
            &#039;hostspec&#039; =&gt; false,
            &#039;port&#039;     =&gt; false,
            &#039;socket&#039;   =&gt; false,
            &#039;database&#039; =&gt; false,
        );

        if (is_array($dsn)) {
            $dsn = array_merge($parsed, $dsn);
            if (!$dsn[&#039;dbsyntax&#039;]) {
                $dsn[&#039;dbsyntax&#039;] = $dsn[&#039;phptype&#039;];
            }
            return $dsn;
        }

        // Find phptype and dbsyntax
        if (($pos = strpos($dsn, &#039;://&#039;)) !== false) {
            $str = substr($dsn, 0, $pos);
            $dsn = substr($dsn, $pos + 3);
        } else {
            $str = $dsn;
            $dsn = null;
        }

        // Get phptype and dbsyntax
        // $str =&gt; phptype(dbsyntax)
        if (preg_match(&#039;|^(.+?)\((.*?)\)$|&#039;, $str, $arr)) {
            $parsed[&#039;phptype&#039;]  = $arr[1];
            $parsed[&#039;dbsyntax&#039;] = !$arr[2] ? $arr[1] : $arr[2];
        } else {
            $parsed[&#039;phptype&#039;]  = $str;
            $parsed[&#039;dbsyntax&#039;] = $str;
        }

        if (!count($dsn)) {
            return $parsed;
        }

        // Get (if found): username and password
        // $dsn =&gt; username:password@protocol+hostspec/database
        if (($at = strrpos($dsn,&#039;@&#039;)) !== false) {
            $str = substr($dsn, 0, $at);
            $dsn = substr($dsn, $at + 1);
            if (($pos = strpos($str, &#039;:&#039;)) !== false) {
                $parsed[&#039;username&#039;] = rawurldecode(substr($str, 0, $pos));
                $parsed[&#039;password&#039;] = rawurldecode(substr($str, $pos + 1));
            } else {
                $parsed[&#039;username&#039;] = rawurldecode($str);
            }
        }

        // Find protocol and hostspec

        if (preg_match(&#039;|^([^(]+)\((.*?)\)/?(.*?)$|&#039;, $dsn, $match)) {
            // $dsn =&gt; proto(proto_opts)/database
            $proto       = $match[1];
            $proto_opts  = $match[2] ? $match[2] : false;
            $dsn         = $match[3];

        } else {
            // $dsn =&gt; protocol+hostspec/database (old format)
            if (strpos($dsn, &#039;+&#039;) !== false) {
                list($proto, $dsn) = explode(&#039;+&#039;, $dsn, 2);
            }
            if (strpos($dsn, &#039;/&#039;) !== false) {
                list($proto_opts, $dsn) = explode(&#039;/&#039;, $dsn, 2);
            } else {
                $proto_opts = $dsn;
                $dsn = null;
            }
        }

        // process the different protocol options
        $parsed[&#039;protocol&#039;] = (!empty($proto)) ? $proto : &#039;tcp&#039;;
        $proto_opts = rawurldecode($proto_opts);
        if ($parsed[&#039;protocol&#039;] == &#039;tcp&#039;) {
            if (strpos($proto_opts, &#039;:&#039;) !== false) {
                list($parsed[&#039;hostspec&#039;],
                     $parsed[&#039;port&#039;]) = explode(&#039;:&#039;, $proto_opts);
            } else {
                $parsed[&#039;hostspec&#039;] = $proto_opts;
            }
        } elseif ($parsed[&#039;protocol&#039;] == &#039;unix&#039;) {
            $parsed[&#039;socket&#039;] = $proto_opts;
        }

        // Get dabase if any
        // $dsn =&gt; database
        if ($dsn) {
            if (($pos = strpos($dsn, &#039;?&#039;)) === false) {
                // /database
                $parsed[&#039;database&#039;] = rawurldecode($dsn);
            } else {
                // /database?param1=value1&amp;param2=value2
                $parsed[&#039;database&#039;] = rawurldecode(substr($dsn, 0, $pos));
                $dsn = substr($dsn, $pos + 1);
                if (strpos($dsn, &#039;&amp;&#039;) !== false) {
                    $opts = explode(&#039;&amp;&#039;, $dsn);
                } else { // database?param1=value1
                    $opts = array($dsn);
                }
                foreach ($opts as $opt) {
                    list($key, $value) = explode(&#039;=&#039;, $opt);
                    if (!isset($parsed[$key])) {
                        // don&#039;t allow params overwrite
                        $parsed[$key] = rawurldecode($value);
                    }
                }
            }
        }

        return $parsed;
    }

    // }}}
}

// }}}
// {{{ class DB_Error

/**
 * DB_Error implements a class for reporting portable database error
 * messages
 *
 * @category   Database
 * @package    DB
 * @author     Stig Bakken &lt;ssb@php.net&gt;
 * @copyright  1997-2005 The PHP Group
 * @license    http://www.php.net/license/3_0.txt  PHP License 3.0
 * @version    Release: 1.7.6
 * @link       http://pear.php.net/package/DB
 */
class DB_Error extends PEAR_Error
{
    // {{{ constructor

    /**
     * DB_Error constructor
     *
     * @param mixed $code       DB error code, or string with error message
     * @param int   $mode       what &quot;error mode&quot; to operate in
     * @param int   $level      what error level to use for $mode &amp;
     *                           PEAR_ERROR_TRIGGER
     * @param mixed $debuginfo  additional debug info, such as the last query
     *
     * @see PEAR_Error
     */
    function DB_Error($code = DB_ERROR, $mode = PEAR_ERROR_RETURN,
                      $level = E_USER_NOTICE, $debuginfo = null)
    {
        if (is_int($code)) {
            $this-&gt;PEAR_Error(&#039;DB Error: &#039; . DB::errorMessage($code), $code,
                              $mode, $level, $debuginfo);
        } else {
            $this-&gt;PEAR_Error(&quot;DB Error: $code&quot;, DB_ERROR,
                              $mode, $level, $debuginfo);
        }
    }

    // }}}
}

// }}}
// {{{ class DB_result

/**
 * This class implements a wrapper for a DB result set
 *
 * A new instance of this class will be returned by the DB implementation
 * after processing a query that returns data.
 *
 * @category   Database
 * @package    DB
 * @author     Stig Bakken &lt;ssb@php.net&gt;
 * @copyright  1997-2005 The PHP Group
 * @license    http://www.php.net/license/3_0.txt  PHP License 3.0
 * @version    Release: 1.7.6
 * @link       http://pear.php.net/package/DB
 */
class DB_result
{
    // {{{ properties

    /**
     * Should results be freed automatically when there are no more rows?
     * @var boolean
     * @see DB_common::$options
     */
    var $autofree;
    /**
     * A reference to the DB_&lt;driver&gt; object
     * @var object
     */
    var $dbh;

    /**
     * The current default fetch mode
     * @var integer
     * @see DB_common::$fetchmode
     */
    var $fetchmode;

    /**
     * The name of the class into which results should be fetched when
     * DB_FETCHMODE_OBJECT is in effect
     *
     * @var string
     * @see DB_common::$fetchmode_object_class
     */
    var $fetchmode_object_class;

    /**
     * The number of rows to fetch from a limit query
     * @var integer
     */
    var $limit_count = null;

    /**
     * The row to start fetching from in limit queries
     * @var integer
     */
    var $limit_from = null;

    /**
     * The execute parameters that created this result
     * @var array
     * @since Property available since Release 1.7.0
     */
    var $parameters;

    /**
     * The query string that created this result
     *
     * Copied here incase it changes in $dbh, which is referenced
     *
     * @var string
     * @since Property available since Release 1.7.0
     */
    var $query;

    /**
     * The query result resource id created by PHP
     * @var resource
     */
    var $result;

    /**
     * The present row being dealt with
     * @var integer
     */
    var $row_counter = null;
    /**
     * The prepared statement resource id created by PHP in $dbh
     *
     * This resource is only available when the result set was created using
     * a driver&#039;s native execute() method, not PEAR DB&#039;s emulated one.
     *
     * Copied here incase it changes in $dbh, which is referenced
     *
     * {@internal  Mainly here because the InterBase/Firebird API is only
     * able to retrieve data from result sets if the statemnt handle is
     * still in scope.}}
     *
     * @var resource
     * @since Property available since Release 1.7.0
     */
    var $statement;


    // }}}
    // {{{ constructor

    /**
     * This constructor sets the object&#039;s properties
     *
     * @param object   &amp;$dbh     the DB object reference
     * @param resource $result   the result resource id
     * @param array    $options  an associative array with result options
     *
     * @return void
     */
    function DB_result(&amp;$dbh, $result, $options = array())
    {
        $this-&gt;autofree    = $dbh-&gt;options[&#039;autofree&#039;];
        $this-&gt;dbh         = &amp;$dbh;
        $this-&gt;fetchmode   = $dbh-&gt;fetchmode;
        $this-&gt;fetchmode_object_class = $dbh-&gt;fetchmode_object_class;
        $this-&gt;parameters  = $dbh-&gt;last_parameters;
        $this-&gt;query       = $dbh-&gt;last_query;
        $this-&gt;result      = $result;
        $this-&gt;statement   = empty($dbh-&gt;last_stmt) ? null : $dbh-&gt;last_stmt;
        foreach ($options as $key =&gt; $value) {
            $this-&gt;setOption($key, $value);
        }
    }

    /**
     * Set options for the DB_result object
     *
     * @param string $key    the option to set
     * @param mixed  $value  the value to set the option to
     *
     * @return void
     */
    function setOption($key, $value = null)
    {
        switch ($key) {
            case &#039;limit_from&#039;:
                $this-&gt;limit_from = $value;
                break;
            case &#039;limit_count&#039;:
                $this-&gt;limit_count = $value;
        }
    }</description>
			<content:encoded><![CDATA[deel2:<br>
<div class="code">PHP:<br><table class="phphighlight"><tr><td class="phphighlightline"><pre>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
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
</pre></td><td class="phphighlightcode"><div><pre>    <span class="code_sd">/**</span>
<span class="code_sd">     * Return a textual error message for a DB error code</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * @param integer $value  the DB error code</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * @return string  the error message or false if the error code was</span>
<span class="code_sd">     *                  not recognized</span>
<span class="code_sd">     */</span>
    <span class="code_k">function</span> <span class="code_nf">errorMessage</span><span class="code_p">(</span><span class="code_nv">$value</span><span class="code_p">)</span>
    <span class="code_p">{</span>
        <span class="code_k">static</span> <span class="code_nv">$errorMessages</span><span class="code_p">;</span>
        <span class="code_k">if</span> <span class="code_p">(</span><span class="code_o">!</span><span class="code_nb">isset</span><span class="code_p">(</span><span class="code_nv">$errorMessages</span><span class="code_p">))</span> <span class="code_p">{</span>
            <span class="code_nv">$errorMessages</span> <span class="code_o">=</span> <span class="code_k">array</span><span class="code_p">(</span>
                <span class="code_nx">DB_ERROR</span>                    <span class="code_o">=&gt;</span> <span class="code_s1">&#39;unknown error&#39;</span><span class="code_p">,</span>
                <span class="code_nx">DB_ERROR_ACCESS_VIOLATION</span>   <span class="code_o">=&gt;</span> <span class="code_s1">&#39;insufficient permissions&#39;</span><span class="code_p">,</span>
                <span class="code_nx">DB_ERROR_ALREADY_EXISTS</span>     <span class="code_o">=&gt;</span> <span class="code_s1">&#39;already exists&#39;</span><span class="code_p">,</span>
                <span class="code_nx">DB_ERROR_CANNOT_CREATE</span>      <span class="code_o">=&gt;</span> <span class="code_s1">&#39;can not create&#39;</span><span class="code_p">,</span>
                <span class="code_nx">DB_ERROR_CANNOT_DROP</span>        <span class="code_o">=&gt;</span> <span class="code_s1">&#39;can not drop&#39;</span><span class="code_p">,</span>
                <span class="code_nx">DB_ERROR_CONNECT_FAILED</span>     <span class="code_o">=&gt;</span> <span class="code_s1">&#39;connect failed&#39;</span><span class="code_p">,</span>
                <span class="code_nx">DB_ERROR_CONSTRAINT</span>         <span class="code_o">=&gt;</span> <span class="code_s1">&#39;constraint violation&#39;</span><span class="code_p">,</span>
                <span class="code_nx">DB_ERROR_CONSTRAINT_NOT_NULL</span><span class="code_o">=&gt;</span> <span class="code_s1">&#39;null value violates not-null constraint&#39;</span><span class="code_p">,</span>
                <span class="code_nx">DB_ERROR_DIVZERO</span>            <span class="code_o">=&gt;</span> <span class="code_s1">&#39;division by zero&#39;</span><span class="code_p">,</span>
                <span class="code_nx">DB_ERROR_EXTENSION_NOT_FOUND</span><span class="code_o">=&gt;</span> <span class="code_s1">&#39;extension not found&#39;</span><span class="code_p">,</span>
                <span class="code_nx">DB_ERROR_INVALID</span>            <span class="code_o">=&gt;</span> <span class="code_s1">&#39;invalid&#39;</span><span class="code_p">,</span>
                <span class="code_nx">DB_ERROR_INVALID_DATE</span>       <span class="code_o">=&gt;</span> <span class="code_s1">&#39;invalid date or time&#39;</span><span class="code_p">,</span>
                <span class="code_nx">DB_ERROR_INVALID_DSN</span>        <span class="code_o">=&gt;</span> <span class="code_s1">&#39;invalid DSN&#39;</span><span class="code_p">,</span>
                <span class="code_nx">DB_ERROR_INVALID_NUMBER</span>     <span class="code_o">=&gt;</span> <span class="code_s1">&#39;invalid number&#39;</span><span class="code_p">,</span>
                <span class="code_nx">DB_ERROR_MISMATCH</span>           <span class="code_o">=&gt;</span> <span class="code_s1">&#39;mismatch&#39;</span><span class="code_p">,</span>
                <span class="code_nx">DB_ERROR_NEED_MORE_DATA</span>     <span class="code_o">=&gt;</span> <span class="code_s1">&#39;insufficient data supplied&#39;</span><span class="code_p">,</span>
                <span class="code_nx">DB_ERROR_NODBSELECTED</span>       <span class="code_o">=&gt;</span> <span class="code_s1">&#39;no database selected&#39;</span><span class="code_p">,</span>
                <span class="code_nx">DB_ERROR_NOSUCHDB</span>           <span class="code_o">=&gt;</span> <span class="code_s1">&#39;no such database&#39;</span><span class="code_p">,</span>
                <span class="code_nx">DB_ERROR_NOSUCHFIELD</span>        <span class="code_o">=&gt;</span> <span class="code_s1">&#39;no such field&#39;</span><span class="code_p">,</span>
                <span class="code_nx">DB_ERROR_NOSUCHTABLE</span>        <span class="code_o">=&gt;</span> <span class="code_s1">&#39;no such table&#39;</span><span class="code_p">,</span>
                <span class="code_nx">DB_ERROR_NOT_CAPABLE</span>        <span class="code_o">=&gt;</span> <span class="code_s1">&#39;DB backend not capable&#39;</span><span class="code_p">,</span>
                <span class="code_nx">DB_ERROR_NOT_FOUND</span>          <span class="code_o">=&gt;</span> <span class="code_s1">&#39;not found&#39;</span><span class="code_p">,</span>
                <span class="code_nx">DB_ERROR_NOT_LOCKED</span>         <span class="code_o">=&gt;</span> <span class="code_s1">&#39;not locked&#39;</span><span class="code_p">,</span>
                <span class="code_nx">DB_ERROR_SYNTAX</span>             <span class="code_o">=&gt;</span> <span class="code_s1">&#39;syntax error&#39;</span><span class="code_p">,</span>
                <span class="code_nx">DB_ERROR_UNSUPPORTED</span>        <span class="code_o">=&gt;</span> <span class="code_s1">&#39;not supported&#39;</span><span class="code_p">,</span>
                <span class="code_nx">DB_ERROR_TRUNCATED</span>          <span class="code_o">=&gt;</span> <span class="code_s1">&#39;truncated&#39;</span><span class="code_p">,</span>
                <span class="code_nx">DB_ERROR_VALUE_COUNT_ON_ROW</span> <span class="code_o">=&gt;</span> <span class="code_s1">&#39;value count on row&#39;</span><span class="code_p">,</span>
                <span class="code_nx">DB_OK</span>                       <span class="code_o">=&gt;</span> <span class="code_s1">&#39;no error&#39;</span><span class="code_p">,</span>
            <span class="code_p">);</span>
        <span class="code_p">}</span>

        <span class="code_k">if</span> <span class="code_p">(</span><span class="code_nx">DB</span><span class="code_o">::</span><span class="code_na">isError</span><span class="code_p">(</span><span class="code_nv">$value</span><span class="code_p">))</span> <span class="code_p">{</span>
            <span class="code_nv">$value</span> <span class="code_o">=</span> <span class="code_nv">$value</span><span class="code_o">-&gt;</span><span class="code_na">getCode</span><span class="code_p">();</span>
        <span class="code_p">}</span>

        <span class="code_k">return</span> <span class="code_nb">isset</span><span class="code_p">(</span><span class="code_nv">$errorMessages</span><span class="code_p">[</span><span class="code_nv">$value</span><span class="code_p">])</span> <span class="code_o">?</span> <span class="code_nv">$errorMessages</span><span class="code_p">[</span><span class="code_nv">$value</span><span class="code_p">]</span>
                     <span class="code_o">:</span> <span class="code_nv">$errorMessages</span><span class="code_p">[</span><span class="code_nx">DB_ERROR</span><span class="code_p">];</span>
    <span class="code_p">}</span>

    <span class="code_c1">// }}}</span>
    <span class="code_c1">// {{{ parseDSN()</span>
    <span class="code_sd">/**</span>
<span class="code_sd">     * Parse a data source name</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * Additional keys can be added by appending a URI query string to the</span>
<span class="code_sd">     * end of the DSN.</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * The format of the supplied DSN is in its fullest form:</span>
<span class="code_sd">     * &lt;code&gt;</span>
<span class="code_sd">     *  phptype(dbsyntax)://username:password@protocol+hostspec/database?option=8&amp;another=true</span>
<span class="code_sd">     * &lt;/code&gt;</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * Most variations are allowed:</span>
<span class="code_sd">     * &lt;code&gt;</span>
<span class="code_sd">     *  phptype://username:password@protocol+hostspec:110//usr/db_file.db?mode=0644</span>
<span class="code_sd">     *  phptype://username:password@hostspec/database_name</span>
<span class="code_sd">     *  phptype://username:password@hostspec</span>
<span class="code_sd">     *  phptype://username@hostspec</span>
<span class="code_sd">     *  phptype://hostspec/database</span>
<span class="code_sd">     *  phptype://hostspec</span>
<span class="code_sd">     *  phptype(dbsyntax)</span>
<span class="code_sd">     *  phptype</span>
<span class="code_sd">     * &lt;/code&gt;</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * @param string $dsn Data Source Name to be parsed</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * @return array an associative array with the following keys:</span>
<span class="code_sd">     *  + phptype:  Database backend used in PHP (mysql, odbc etc.)</span>
<span class="code_sd">     *  + dbsyntax: Database used with regards to SQL syntax etc.</span>
<span class="code_sd">     *  + protocol: Communication protocol to use (tcp, unix etc.)</span>
<span class="code_sd">     *  + hostspec: Host specification (hostname[:port])</span>
<span class="code_sd">     *  + database: Database to use on the DBMS server</span>
<span class="code_sd">     *  + username: User name for login</span>
<span class="code_sd">     *  + password: Password for login</span>
<span class="code_sd">     */</span>
    <span class="code_k">function</span> <span class="code_nf">parseDSN</span><span class="code_p">(</span><span class="code_nv">$dsn</span><span class="code_p">)</span>
    <span class="code_p">{</span>
        <span class="code_nv">$parsed</span> <span class="code_o">=</span> <span class="code_k">array</span><span class="code_p">(</span>
            <span class="code_s1">&#39;phptype&#39;</span>  <span class="code_o">=&gt;</span> <span class="code_k">false</span><span class="code_p">,</span>
            <span class="code_s1">&#39;dbsyntax&#39;</span> <span class="code_o">=&gt;</span> <span class="code_k">false</span><span class="code_p">,</span>
            <span class="code_s1">&#39;username&#39;</span> <span class="code_o">=&gt;</span> <span class="code_k">false</span><span class="code_p">,</span>
            <span class="code_s1">&#39;password&#39;</span> <span class="code_o">=&gt;</span> <span class="code_k">false</span><span class="code_p">,</span>
            <span class="code_s1">&#39;protocol&#39;</span> <span class="code_o">=&gt;</span> <span class="code_k">false</span><span class="code_p">,</span>
            <span class="code_s1">&#39;hostspec&#39;</span> <span class="code_o">=&gt;</span> <span class="code_k">false</span><span class="code_p">,</span>
            <span class="code_s1">&#39;port&#39;</span>     <span class="code_o">=&gt;</span> <span class="code_k">false</span><span class="code_p">,</span>
            <span class="code_s1">&#39;socket&#39;</span>   <span class="code_o">=&gt;</span> <span class="code_k">false</span><span class="code_p">,</span>
            <span class="code_s1">&#39;database&#39;</span> <span class="code_o">=&gt;</span> <span class="code_k">false</span><span class="code_p">,</span>
        <span class="code_p">);</span>

        <span class="code_k">if</span> <span class="code_p">(</span><span class="code_nb">is_array</span><span class="code_p">(</span><span class="code_nv">$dsn</span><span class="code_p">))</span> <span class="code_p">{</span>
            <span class="code_nv">$dsn</span> <span class="code_o">=</span> <span class="code_nb">array_merge</span><span class="code_p">(</span><span class="code_nv">$parsed</span><span class="code_p">,</span> <span class="code_nv">$dsn</span><span class="code_p">);</span>
            <span class="code_k">if</span> <span class="code_p">(</span><span class="code_o">!</span><span class="code_nv">$dsn</span><span class="code_p">[</span><span class="code_s1">&#39;dbsyntax&#39;</span><span class="code_p">])</span> <span class="code_p">{</span>
                <span class="code_nv">$dsn</span><span class="code_p">[</span><span class="code_s1">&#39;dbsyntax&#39;</span><span class="code_p">]</span> <span class="code_o">=</span> <span class="code_nv">$dsn</span><span class="code_p">[</span><span class="code_s1">&#39;phptype&#39;</span><span class="code_p">];</span>
            <span class="code_p">}</span>
            <span class="code_k">return</span> <span class="code_nv">$dsn</span><span class="code_p">;</span>
        <span class="code_p">}</span>

        <span class="code_c1">// Find phptype and dbsyntax</span>
        <span class="code_k">if</span> <span class="code_p">((</span><span class="code_nv">$pos</span> <span class="code_o">=</span> <span class="code_nb">strpos</span><span class="code_p">(</span><span class="code_nv">$dsn</span><span class="code_p">,</span> <span class="code_s1">&#39;://&#39;</span><span class="code_p">))</span> <span class="code_o">!==</span> <span class="code_k">false</span><span class="code_p">)</span> <span class="code_p">{</span>
            <span class="code_nv">$str</span> <span class="code_o">=</span> <span class="code_nb">substr</span><span class="code_p">(</span><span class="code_nv">$dsn</span><span class="code_p">,</span> <span class="code_mi">0</span><span class="code_p">,</span> <span class="code_nv">$pos</span><span class="code_p">);</span>
            <span class="code_nv">$dsn</span> <span class="code_o">=</span> <span class="code_nb">substr</span><span class="code_p">(</span><span class="code_nv">$dsn</span><span class="code_p">,</span> <span class="code_nv">$pos</span> <span class="code_o">+</span> <span class="code_mi">3</span><span class="code_p">);</span>
        <span class="code_p">}</span> <span class="code_k">else</span> <span class="code_p">{</span>
            <span class="code_nv">$str</span> <span class="code_o">=</span> <span class="code_nv">$dsn</span><span class="code_p">;</span>
            <span class="code_nv">$dsn</span> <span class="code_o">=</span> <span class="code_k">null</span><span class="code_p">;</span>
        <span class="code_p">}</span>

        <span class="code_c1">// Get phptype and dbsyntax</span>
        <span class="code_c1">// $str =&gt; phptype(dbsyntax)</span>
        <span class="code_k">if</span> <span class="code_p">(</span><span class="code_nb">preg_match</span><span class="code_p">(</span><span class="code_s1">&#39;|^(.+?)\((.*?)\)$|&#39;</span><span class="code_p">,</span> <span class="code_nv">$str</span><span class="code_p">,</span> <span class="code_nv">$arr</span><span class="code_p">))</span> <span class="code_p">{</span>
            <span class="code_nv">$parsed</span><span class="code_p">[</span><span class="code_s1">&#39;phptype&#39;</span><span class="code_p">]</span>  <span class="code_o">=</span> <span class="code_nv">$arr</span><span class="code_p">[</span><span class="code_mi">1</span><span class="code_p">];</span>
            <span class="code_nv">$parsed</span><span class="code_p">[</span><span class="code_s1">&#39;dbsyntax&#39;</span><span class="code_p">]</span> <span class="code_o">=</span> <span class="code_o">!</span><span class="code_nv">$arr</span><span class="code_p">[</span><span class="code_mi">2</span><span class="code_p">]</span> <span class="code_o">?</span> <span class="code_nv">$arr</span><span class="code_p">[</span><span class="code_mi">1</span><span class="code_p">]</span> <span class="code_o">:</span> <span class="code_nv">$arr</span><span class="code_p">[</span><span class="code_mi">2</span><span class="code_p">];</span>
        <span class="code_p">}</span> <span class="code_k">else</span> <span class="code_p">{</span>
            <span class="code_nv">$parsed</span><span class="code_p">[</span><span class="code_s1">&#39;phptype&#39;</span><span class="code_p">]</span>  <span class="code_o">=</span> <span class="code_nv">$str</span><span class="code_p">;</span>
            <span class="code_nv">$parsed</span><span class="code_p">[</span><span class="code_s1">&#39;dbsyntax&#39;</span><span class="code_p">]</span> <span class="code_o">=</span> <span class="code_nv">$str</span><span class="code_p">;</span>
        <span class="code_p">}</span>

        <span class="code_k">if</span> <span class="code_p">(</span><span class="code_o">!</span><span class="code_nb">count</span><span class="code_p">(</span><span class="code_nv">$dsn</span><span class="code_p">))</span> <span class="code_p">{</span>
            <span class="code_k">return</span> <span class="code_nv">$parsed</span><span class="code_p">;</span>
        <span class="code_p">}</span>

        <span class="code_c1">// Get (if found): username and password</span>
        <span class="code_c1">// $dsn =&gt; username:password@protocol+hostspec/database</span>
        <span class="code_k">if</span> <span class="code_p">((</span><span class="code_nv">$at</span> <span class="code_o">=</span> <span class="code_nb">strrpos</span><span class="code_p">(</span><span class="code_nv">$dsn</span><span class="code_p">,</span><span class="code_s1">&#39;@&#39;</span><span class="code_p">))</span> <span class="code_o">!==</span> <span class="code_k">false</span><span class="code_p">)</span> <span class="code_p">{</span>
            <span class="code_nv">$str</span> <span class="code_o">=</span> <span class="code_nb">substr</span><span class="code_p">(</span><span class="code_nv">$dsn</span><span class="code_p">,</span> <span class="code_mi">0</span><span class="code_p">,</span> <span class="code_nv">$at</span><span class="code_p">);</span>
            <span class="code_nv">$dsn</span> <span class="code_o">=</span> <span class="code_nb">substr</span><span class="code_p">(</span><span class="code_nv">$dsn</span><span class="code_p">,</span> <span class="code_nv">$at</span> <span class="code_o">+</span> <span class="code_mi">1</span><span class="code_p">);</span>
            <span class="code_k">if</span> <span class="code_p">((</span><span class="code_nv">$pos</span> <span class="code_o">=</span> <span class="code_nb">strpos</span><span class="code_p">(</span><span class="code_nv">$str</span><span class="code_p">,</span> <span class="code_s1">&#39;:&#39;</span><span class="code_p">))</span> <span class="code_o">!==</span> <span class="code_k">false</span><span class="code_p">)</span> <span class="code_p">{</span>
                <span class="code_nv">$parsed</span><span class="code_p">[</span><span class="code_s1">&#39;username&#39;</span><span class="code_p">]</span> <span class="code_o">=</span> <span class="code_nb">rawurldecode</span><span class="code_p">(</span><span class="code_nb">substr</span><span class="code_p">(</span><span class="code_nv">$str</span><span class="code_p">,</span> <span class="code_mi">0</span><span class="code_p">,</span> <span class="code_nv">$pos</span><span class="code_p">));</span>
                <span class="code_nv">$parsed</span><span class="code_p">[</span><span class="code_s1">&#39;password&#39;</span><span class="code_p">]</span> <span class="code_o">=</span> <span class="code_nb">rawurldecode</span><span class="code_p">(</span><span class="code_nb">substr</span><span class="code_p">(</span><span class="code_nv">$str</span><span class="code_p">,</span> <span class="code_nv">$pos</span> <span class="code_o">+</span> <span class="code_mi">1</span><span class="code_p">));</span>
            <span class="code_p">}</span> <span class="code_k">else</span> <span class="code_p">{</span>
                <span class="code_nv">$parsed</span><span class="code_p">[</span><span class="code_s1">&#39;username&#39;</span><span class="code_p">]</span> <span class="code_o">=</span> <span class="code_nb">rawurldecode</span><span class="code_p">(</span><span class="code_nv">$str</span><span class="code_p">);</span>
            <span class="code_p">}</span>
        <span class="code_p">}</span>

        <span class="code_c1">// Find protocol and hostspec</span>

        <span class="code_k">if</span> <span class="code_p">(</span><span class="code_nb">preg_match</span><span class="code_p">(</span><span class="code_s1">&#39;|^([^(]+)\((.*?)\)/?(.*?)$|&#39;</span><span class="code_p">,</span> <span class="code_nv">$dsn</span><span class="code_p">,</span> <span class="code_nv">$match</span><span class="code_p">))</span> <span class="code_p">{</span>
            <span class="code_c1">// $dsn =&gt; proto(proto_opts)/database</span>
            <span class="code_nv">$proto</span>       <span class="code_o">=</span> <span class="code_nv">$match</span><span class="code_p">[</span><span class="code_mi">1</span><span class="code_p">];</span>
            <span class="code_nv">$proto_opts</span>  <span class="code_o">=</span> <span class="code_nv">$match</span><span class="code_p">[</span><span class="code_mi">2</span><span class="code_p">]</span> <span class="code_o">?</span> <span class="code_nv">$match</span><span class="code_p">[</span><span class="code_mi">2</span><span class="code_p">]</span> <span class="code_o">:</span> <span class="code_k">false</span><span class="code_p">;</span>
            <span class="code_nv">$dsn</span>         <span class="code_o">=</span> <span class="code_nv">$match</span><span class="code_p">[</span><span class="code_mi">3</span><span class="code_p">];</span>

        <span class="code_p">}</span> <span class="code_k">else</span> <span class="code_p">{</span>
            <span class="code_c1">// $dsn =&gt; protocol+hostspec/database (old format)</span>
            <span class="code_k">if</span> <span class="code_p">(</span><span class="code_nb">strpos</span><span class="code_p">(</span><span class="code_nv">$dsn</span><span class="code_p">,</span> <span class="code_s1">&#39;+&#39;</span><span class="code_p">)</span> <span class="code_o">!==</span> <span class="code_k">false</span><span class="code_p">)</span> <span class="code_p">{</span>
                <span class="code_k">list</span><span class="code_p">(</span><span class="code_nv">$proto</span><span class="code_p">,</span> <span class="code_nv">$dsn</span><span class="code_p">)</span> <span class="code_o">=</span> <span class="code_nb">explode</span><span class="code_p">(</span><span class="code_s1">&#39;+&#39;</span><span class="code_p">,</span> <span class="code_nv">$dsn</span><span class="code_p">,</span> <span class="code_mi">2</span><span class="code_p">);</span>
            <span class="code_p">}</span>
            <span class="code_k">if</span> <span class="code_p">(</span><span class="code_nb">strpos</span><span class="code_p">(</span><span class="code_nv">$dsn</span><span class="code_p">,</span> <span class="code_s1">&#39;/&#39;</span><span class="code_p">)</span> <span class="code_o">!==</span> <span class="code_k">false</span><span class="code_p">)</span> <span class="code_p">{</span>
                <span class="code_k">list</span><span class="code_p">(</span><span class="code_nv">$proto_opts</span><span class="code_p">,</span> <span class="code_nv">$dsn</span><span class="code_p">)</span> <span class="code_o">=</span> <span class="code_nb">explode</span><span class="code_p">(</span><span class="code_s1">&#39;/&#39;</span><span class="code_p">,</span> <span class="code_nv">$dsn</span><span class="code_p">,</span> <span class="code_mi">2</span><span class="code_p">);</span>
            <span class="code_p">}</span> <span class="code_k">else</span> <span class="code_p">{</span>
                <span class="code_nv">$proto_opts</span> <span class="code_o">=</span> <span class="code_nv">$dsn</span><span class="code_p">;</span>
                <span class="code_nv">$dsn</span> <span class="code_o">=</span> <span class="code_k">null</span><span class="code_p">;</span>
            <span class="code_p">}</span>
        <span class="code_p">}</span>

        <span class="code_c1">// process the different protocol options</span>
        <span class="code_nv">$parsed</span><span class="code_p">[</span><span class="code_s1">&#39;protocol&#39;</span><span class="code_p">]</span> <span class="code_o">=</span> <span class="code_p">(</span><span class="code_o">!</span><span class="code_k">empty</span><span class="code_p">(</span><span class="code_nv">$proto</span><span class="code_p">))</span> <span class="code_o">?</span> <span class="code_nv">$proto</span> <span class="code_o">:</span> <span class="code_s1">&#39;tcp&#39;</span><span class="code_p">;</span>
        <span class="code_nv">$proto_opts</span> <span class="code_o">=</span> <span class="code_nb">rawurldecode</span><span class="code_p">(</span><span class="code_nv">$proto_opts</span><span class="code_p">);</span>
        <span class="code_k">if</span> <span class="code_p">(</span><span class="code_nv">$parsed</span><span class="code_p">[</span><span class="code_s1">&#39;protocol&#39;</span><span class="code_p">]</span> <span class="code_o">==</span> <span class="code_s1">&#39;tcp&#39;</span><span class="code_p">)</span> <span class="code_p">{</span>
            <span class="code_k">if</span> <span class="code_p">(</span><span class="code_nb">strpos</span><span class="code_p">(</span><span class="code_nv">$proto_opts</span><span class="code_p">,</span> <span class="code_s1">&#39;:&#39;</span><span class="code_p">)</span> <span class="code_o">!==</span> <span class="code_k">false</span><span class="code_p">)</span> <span class="code_p">{</span>
                <span class="code_k">list</span><span class="code_p">(</span><span class="code_nv">$parsed</span><span class="code_p">[</span><span class="code_s1">&#39;hostspec&#39;</span><span class="code_p">],</span>
                     <span class="code_nv">$parsed</span><span class="code_p">[</span><span class="code_s1">&#39;port&#39;</span><span class="code_p">])</span> <span class="code_o">=</span> <span class="code_nb">explode</span><span class="code_p">(</span><span class="code_s1">&#39;:&#39;</span><span class="code_p">,</span> <span class="code_nv">$proto_opts</span><span class="code_p">);</span>
            <span class="code_p">}</span> <span class="code_k">else</span> <span class="code_p">{</span>
                <span class="code_nv">$parsed</span><span class="code_p">[</span><span class="code_s1">&#39;hostspec&#39;</span><span class="code_p">]</span> <span class="code_o">=</span> <span class="code_nv">$proto_opts</span><span class="code_p">;</span>
            <span class="code_p">}</span>
        <span class="code_p">}</span> <span class="code_k">elseif</span> <span class="code_p">(</span><span class="code_nv">$parsed</span><span class="code_p">[</span><span class="code_s1">&#39;protocol&#39;</span><span class="code_p">]</span> <span class="code_o">==</span> <span class="code_s1">&#39;unix&#39;</span><span class="code_p">)</span> <span class="code_p">{</span>
            <span class="code_nv">$parsed</span><span class="code_p">[</span><span class="code_s1">&#39;socket&#39;</span><span class="code_p">]</span> <span class="code_o">=</span> <span class="code_nv">$proto_opts</span><span class="code_p">;</span>
        <span class="code_p">}</span>

        <span class="code_c1">// Get dabase if any</span>
        <span class="code_c1">// $dsn =&gt; database</span>
        <span class="code_k">if</span> <span class="code_p">(</span><span class="code_nv">$dsn</span><span class="code_p">)</span> <span class="code_p">{</span>
            <span class="code_k">if</span> <span class="code_p">((</span><span class="code_nv">$pos</span> <span class="code_o">=</span> <span class="code_nb">strpos</span><span class="code_p">(</span><span class="code_nv">$dsn</span><span class="code_p">,</span> <span class="code_s1">&#39;?&#39;</span><span class="code_p">))</span> <span class="code_o">===</span> <span class="code_k">false</span><span class="code_p">)</span> <span class="code_p">{</span>
                <span class="code_c1">// /database</span>
                <span class="code_nv">$parsed</span><span class="code_p">[</span><span class="code_s1">&#39;database&#39;</span><span class="code_p">]</span> <span class="code_o">=</span> <span class="code_nb">rawurldecode</span><span class="code_p">(</span><span class="code_nv">$dsn</span><span class="code_p">);</span>
            <span class="code_p">}</span> <span class="code_k">else</span> <span class="code_p">{</span>
                <span class="code_c1">// /database?param1=value1&amp;param2=value2</span>
                <span class="code_nv">$parsed</span><span class="code_p">[</span><span class="code_s1">&#39;database&#39;</span><span class="code_p">]</span> <span class="code_o">=</span> <span class="code_nb">rawurldecode</span><span class="code_p">(</span><span class="code_nb">substr</span><span class="code_p">(</span><span class="code_nv">$dsn</span><span class="code_p">,</span> <span class="code_mi">0</span><span class="code_p">,</span> <span class="code_nv">$pos</span><span class="code_p">));</span>
                <span class="code_nv">$dsn</span> <span class="code_o">=</span> <span class="code_nb">substr</span><span class="code_p">(</span><span class="code_nv">$dsn</span><span class="code_p">,</span> <span class="code_nv">$pos</span> <span class="code_o">+</span> <span class="code_mi">1</span><span class="code_p">);</span>
                <span class="code_k">if</span> <span class="code_p">(</span><span class="code_nb">strpos</span><span class="code_p">(</span><span class="code_nv">$dsn</span><span class="code_p">,</span> <span class="code_s1">&#39;&amp;&#39;</span><span class="code_p">)</span> <span class="code_o">!==</span> <span class="code_k">false</span><span class="code_p">)</span> <span class="code_p">{</span>
                    <span class="code_nv">$opts</span> <span class="code_o">=</span> <span class="code_nb">explode</span><span class="code_p">(</span><span class="code_s1">&#39;&amp;&#39;</span><span class="code_p">,</span> <span class="code_nv">$dsn</span><span class="code_p">);</span>
                <span class="code_p">}</span> <span class="code_k">else</span> <span class="code_p">{</span> <span class="code_c1">// database?param1=value1</span>
                    <span class="code_nv">$opts</span> <span class="code_o">=</span> <span class="code_k">array</span><span class="code_p">(</span><span class="code_nv">$dsn</span><span class="code_p">);</span>
                <span class="code_p">}</span>
                <span class="code_k">foreach</span> <span class="code_p">(</span><span class="code_nv">$opts</span> <span class="code_k">as</span> <span class="code_nv">$opt</span><span class="code_p">)</span> <span class="code_p">{</span>
                    <span class="code_k">list</span><span class="code_p">(</span><span class="code_nv">$key</span><span class="code_p">,</span> <span class="code_nv">$value</span><span class="code_p">)</span> <span class="code_o">=</span> <span class="code_nb">explode</span><span class="code_p">(</span><span class="code_s1">&#39;=&#39;</span><span class="code_p">,</span> <span class="code_nv">$opt</span><span class="code_p">);</span>
                    <span class="code_k">if</span> <span class="code_p">(</span><span class="code_o">!</span><span class="code_nb">isset</span><span class="code_p">(</span><span class="code_nv">$parsed</span><span class="code_p">[</span><span class="code_nv">$key</span><span class="code_p">]))</span> <span class="code_p">{</span>
                        <span class="code_c1">// don&#39;t allow params overwrite</span>
                        <span class="code_nv">$parsed</span><span class="code_p">[</span><span class="code_nv">$key</span><span class="code_p">]</span> <span class="code_o">=</span> <span class="code_nb">rawurldecode</span><span class="code_p">(</span><span class="code_nv">$value</span><span class="code_p">);</span>
                    <span class="code_p">}</span>
                <span class="code_p">}</span>
            <span class="code_p">}</span>
        <span class="code_p">}</span>

        <span class="code_k">return</span> <span class="code_nv">$parsed</span><span class="code_p">;</span>
    <span class="code_p">}</span>

    <span class="code_c1">// }}}</span>
<span class="code_p">}</span>

<span class="code_c1">// }}}</span>
<span class="code_c1">// {{{ class DB_Error</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * DB_Error implements a class for reporting portable database error</span>
<span class="code_sd"> * messages</span>
<span class="code_sd"> *</span>
<span class="code_sd"> * @category   Database</span>
<span class="code_sd"> * @package    DB</span>
<span class="code_sd"> * @author     Stig Bakken &lt;ssb@php.net&gt;</span>
<span class="code_sd"> * @copyright  1997-2005 The PHP Group</span>
<span class="code_sd"> * @license    http://www.php.net/license/3_0.txt  PHP License 3.0</span>
<span class="code_sd"> * @version    Release: 1.7.6</span>
<span class="code_sd"> * @link       http://pear.php.net/package/DB</span>
<span class="code_sd"> */</span>
<span class="code_k">class</span> <span class="code_nc">DB_Error</span> <span class="code_k">extends</span> <span class="code_nx">PEAR_Error</span>
<span class="code_p">{</span>
    <span class="code_c1">// {{{ constructor</span>

    <span class="code_sd">/**</span>
<span class="code_sd">     * DB_Error constructor</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * @param mixed $code       DB error code, or string with error message</span>
<span class="code_sd">     * @param int   $mode       what &quot;error mode&quot; to operate in</span>
<span class="code_sd">     * @param int   $level      what error level to use for $mode &amp;</span>
<span class="code_sd">     *                           PEAR_ERROR_TRIGGER</span>
<span class="code_sd">     * @param mixed $debuginfo  additional debug info, such as the last query</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * @see PEAR_Error</span>
<span class="code_sd">     */</span>
    <span class="code_k">function</span> <span class="code_nf">DB_Error</span><span class="code_p">(</span><span class="code_nv">$code</span> <span class="code_o">=</span> <span class="code_nx">DB_ERROR</span><span class="code_p">,</span> <span class="code_nv">$mode</span> <span class="code_o">=</span> <span class="code_nx">PEAR_ERROR_RETURN</span><span class="code_p">,</span>
                      <span class="code_nv">$level</span> <span class="code_o">=</span> <span class="code_nx">E_USER_NOTICE</span><span class="code_p">,</span> <span class="code_nv">$debuginfo</span> <span class="code_o">=</span> <span class="code_k">null</span><span class="code_p">)</span>
    <span class="code_p">{</span>
        <span class="code_k">if</span> <span class="code_p">(</span><span class="code_nb">is_int</span><span class="code_p">(</span><span class="code_nv">$code</span><span class="code_p">))</span> <span class="code_p">{</span>
            <span class="code_nv">$this</span><span class="code_o">-&gt;</span><span class="code_na">PEAR_Error</span><span class="code_p">(</span><span class="code_s1">&#39;DB Error: &#39;</span> <span class="code_o">.</span> <span class="code_nx">DB</span><span class="code_o">::</span><span class="code_na">errorMessage</span><span class="code_p">(</span><span class="code_nv">$code</span><span class="code_p">),</span> <span class="code_nv">$code</span><span class="code_p">,</span>
                              <span class="code_nv">$mode</span><span class="code_p">,</span> <span class="code_nv">$level</span><span class="code_p">,</span> <span class="code_nv">$debuginfo</span><span class="code_p">);</span>
        <span class="code_p">}</span> <span class="code_k">else</span> <span class="code_p">{</span>
            <span class="code_nv">$this</span><span class="code_o">-&gt;</span><span class="code_na">PEAR_Error</span><span class="code_p">(</span><span class="code_s2">&quot;DB Error: </span><span class="code_si">$code</span><span class="code_s2">&quot;</span><span class="code_p">,</span> <span class="code_nx">DB_ERROR</span><span class="code_p">,</span>
                              <span class="code_nv">$mode</span><span class="code_p">,</span> <span class="code_nv">$level</span><span class="code_p">,</span> <span class="code_nv">$debuginfo</span><span class="code_p">);</span>
        <span class="code_p">}</span>
    <span class="code_p">}</span>

    <span class="code_c1">// }}}</span>
<span class="code_p">}</span>

<span class="code_c1">// }}}</span>
<span class="code_c1">// {{{ class DB_result</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * This class implements a wrapper for a DB result set</span>
<span class="code_sd"> *</span>
<span class="code_sd"> * A new instance of this class will be returned by the DB implementation</span>
<span class="code_sd"> * after processing a query that returns data.</span>
<span class="code_sd"> *</span>
<span class="code_sd"> * @category   Database</span>
<span class="code_sd"> * @package    DB</span>
<span class="code_sd"> * @author     Stig Bakken &lt;ssb@php.net&gt;</span>
<span class="code_sd"> * @copyright  1997-2005 The PHP Group</span>
<span class="code_sd"> * @license    http://www.php.net/license/3_0.txt  PHP License 3.0</span>
<span class="code_sd"> * @version    Release: 1.7.6</span>
<span class="code_sd"> * @link       http://pear.php.net/package/DB</span>
<span class="code_sd"> */</span>
<span class="code_k">class</span> <span class="code_nc">DB_result</span>
<span class="code_p">{</span>
    <span class="code_c1">// {{{ properties</span>

    <span class="code_sd">/**</span>
<span class="code_sd">     * Should results be freed automatically when there are no more rows?</span>
<span class="code_sd">     * @var boolean</span>
<span class="code_sd">     * @see DB_common::$options</span>
<span class="code_sd">     */</span>
    <span class="code_k">var</span> <span class="code_nv">$autofree</span><span class="code_p">;</span>
    <span class="code_sd">/**</span>
<span class="code_sd">     * A reference to the DB_&lt;driver&gt; object</span>
<span class="code_sd">     * @var object</span>
<span class="code_sd">     */</span>
    <span class="code_k">var</span> <span class="code_nv">$dbh</span><span class="code_p">;</span>

    <span class="code_sd">/**</span>
<span class="code_sd">     * The current default fetch mode</span>
<span class="code_sd">     * @var integer</span>
<span class="code_sd">     * @see DB_common::$fetchmode</span>
<span class="code_sd">     */</span>
    <span class="code_k">var</span> <span class="code_nv">$fetchmode</span><span class="code_p">;</span>

    <span class="code_sd">/**</span>
<span class="code_sd">     * The name of the class into which results should be fetched when</span>
<span class="code_sd">     * DB_FETCHMODE_OBJECT is in effect</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * @var string</span>
<span class="code_sd">     * @see DB_common::$fetchmode_object_class</span>
<span class="code_sd">     */</span>
    <span class="code_k">var</span> <span class="code_nv">$fetchmode_object_class</span><span class="code_p">;</span>

    <span class="code_sd">/**</span>
<span class="code_sd">     * The number of rows to fetch from a limit query</span>
<span class="code_sd">     * @var integer</span>
<span class="code_sd">     */</span>
    <span class="code_k">var</span> <span class="code_nv">$limit_count</span> <span class="code_o">=</span> <span class="code_k">null</span><span class="code_p">;</span>

    <span class="code_sd">/**</span>
<span class="code_sd">     * The row to start fetching from in limit queries</span>
<span class="code_sd">     * @var integer</span>
<span class="code_sd">     */</span>
    <span class="code_k">var</span> <span class="code_nv">$limit_from</span> <span class="code_o">=</span> <span class="code_k">null</span><span class="code_p">;</span>

    <span class="code_sd">/**</span>
<span class="code_sd">     * The execute parameters that created this result</span>
<span class="code_sd">     * @var array</span>
<span class="code_sd">     * @since Property available since Release 1.7.0</span>
<span class="code_sd">     */</span>
    <span class="code_k">var</span> <span class="code_nv">$parameters</span><span class="code_p">;</span>

    <span class="code_sd">/**</span>
<span class="code_sd">     * The query string that created this result</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * Copied here incase it changes in $dbh, which is referenced</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * @var string</span>
<span class="code_sd">     * @since Property available since Release 1.7.0</span>
<span class="code_sd">     */</span>
    <span class="code_k">var</span> <span class="code_nv">$query</span><span class="code_p">;</span>

    <span class="code_sd">/**</span>
<span class="code_sd">     * The query result resource id created by PHP</span>
<span class="code_sd">     * @var resource</span>
<span class="code_sd">     */</span>
    <span class="code_k">var</span> <span class="code_nv">$result</span><span class="code_p">;</span>

    <span class="code_sd">/**</span>
<span class="code_sd">     * The present row being dealt with</span>
<span class="code_sd">     * @var integer</span>
<span class="code_sd">     */</span>
    <span class="code_k">var</span> <span class="code_nv">$row_counter</span> <span class="code_o">=</span> <span class="code_k">null</span><span class="code_p">;</span>
    <span class="code_sd">/**</span>
<span class="code_sd">     * The prepared statement resource id created by PHP in $dbh</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * This resource is only available when the result set was created using</span>
<span class="code_sd">     * a driver&#39;s native execute() method, not PEAR DB&#39;s emulated one.</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * Copied here incase it changes in $dbh, which is referenced</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * {@internal  Mainly here because the InterBase/Firebird API is only</span>
<span class="code_sd">     * able to retrieve data from result sets if the statemnt handle is</span>
<span class="code_sd">     * still in scope.}}</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * @var resource</span>
<span class="code_sd">     * @since Property available since Release 1.7.0</span>
<span class="code_sd">     */</span>
    <span class="code_k">var</span> <span class="code_nv">$statement</span><span class="code_p">;</span>


    <span class="code_c1">// }}}</span>
    <span class="code_c1">// {{{ constructor</span>

    <span class="code_sd">/**</span>
<span class="code_sd">     * This constructor sets the object&#39;s properties</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * @param object   &amp;$dbh     the DB object reference</span>
<span class="code_sd">     * @param resource $result   the result resource id</span>
<span class="code_sd">     * @param array    $options  an associative array with result options</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * @return void</span>
<span class="code_sd">     */</span>
    <span class="code_k">function</span> <span class="code_nf">DB_result</span><span class="code_p">(</span><span class="code_o">&amp;</span><span class="code_nv">$dbh</span><span class="code_p">,</span> <span class="code_nv">$result</span><span class="code_p">,</span> <span class="code_nv">$options</span> <span class="code_o">=</span> <span class="code_k">array</span><span class="code_p">())</span>
    <span class="code_p">{</span>
        <span class="code_nv">$this</span><span class="code_o">-&gt;</span><span class="code_na">autofree</span>    <span class="code_o">=</span> <span class="code_nv">$dbh</span><span class="code_o">-&gt;</span><span class="code_na">options</span><span class="code_p">[</span><span class="code_s1">&#39;autofree&#39;</span><span class="code_p">];</span>
        <span class="code_nv">$this</span><span class="code_o">-&gt;</span><span class="code_na">dbh</span>         <span class="code_o">=</span> <span class="code_o">&amp;</span><span class="code_nv">$dbh</span><span class="code_p">;</span>
        <span class="code_nv">$this</span><span class="code_o">-&gt;</span><span class="code_na">fetchmode</span>   <span class="code_o">=</span> <span class="code_nv">$dbh</span><span class="code_o">-&gt;</span><span class="code_na">fetchmode</span><span class="code_p">;</span>
        <span class="code_nv">$this</span><span class="code_o">-&gt;</span><span class="code_na">fetchmode_object_class</span> <span class="code_o">=</span> <span class="code_nv">$dbh</span><span class="code_o">-&gt;</span><span class="code_na">fetchmode_object_class</span><span class="code_p">;</span>
        <span class="code_nv">$this</span><span class="code_o">-&gt;</span><span class="code_na">parameters</span>  <span class="code_o">=</span> <span class="code_nv">$dbh</span><span class="code_o">-&gt;</span><span class="code_na">last_parameters</span><span class="code_p">;</span>
        <span class="code_nv">$this</span><span class="code_o">-&gt;</span><span class="code_na">query</span>       <span class="code_o">=</span> <span class="code_nv">$dbh</span><span class="code_o">-&gt;</span><span class="code_na">last_query</span><span class="code_p">;</span>
        <span class="code_nv">$this</span><span class="code_o">-&gt;</span><span class="code_na">result</span>      <span class="code_o">=</span> <span class="code_nv">$result</span><span class="code_p">;</span>
        <span class="code_nv">$this</span><span class="code_o">-&gt;</span><span class="code_na">statement</span>   <span class="code_o">=</span> <span class="code_k">empty</span><span class="code_p">(</span><span class="code_nv">$dbh</span><span class="code_o">-&gt;</span><span class="code_na">last_stmt</span><span class="code_p">)</span> <span class="code_o">?</span> <span class="code_k">null</span> <span class="code_o">:</span> <span class="code_nv">$dbh</span><span class="code_o">-&gt;</span><span class="code_na">last_stmt</span><span class="code_p">;</span>
        <span class="code_k">foreach</span> <span class="code_p">(</span><span class="code_nv">$options</span> <span class="code_k">as</span> <span class="code_nv">$key</span> <span class="code_o">=&gt;</span> <span class="code_nv">$value</span><span class="code_p">)</span> <span class="code_p">{</span>
            <span class="code_nv">$this</span><span class="code_o">-&gt;</span><span class="code_na">setOption</span><span class="code_p">(</span><span class="code_nv">$key</span><span class="code_p">,</span> <span class="code_nv">$value</span><span class="code_p">);</span>
        <span class="code_p">}</span>
    <span class="code_p">}</span>

    <span class="code_sd">/**</span>
<span class="code_sd">     * Set options for the DB_result object</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * @param string $key    the option to set</span>
<span class="code_sd">     * @param mixed  $value  the value to set the option to</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * @return void</span>
<span class="code_sd">     */</span>
    <span class="code_k">function</span> <span class="code_nf">setOption</span><span class="code_p">(</span><span class="code_nv">$key</span><span class="code_p">,</span> <span class="code_nv">$value</span> <span class="code_o">=</span> <span class="code_k">null</span><span class="code_p">)</span>
    <span class="code_p">{</span>
        <span class="code_k">switch</span> <span class="code_p">(</span><span class="code_nv">$key</span><span class="code_p">)</span> <span class="code_p">{</span>
            <span class="code_k">case</span> <span class="code_s1">&#39;limit_from&#39;</span><span class="code_o">:</span>
                <span class="code_nv">$this</span><span class="code_o">-&gt;</span><span class="code_na">limit_from</span> <span class="code_o">=</span> <span class="code_nv">$value</span><span class="code_p">;</span>
                <span class="code_k">break</span><span class="code_p">;</span>
            <span class="code_k">case</span> <span class="code_s1">&#39;limit_count&#39;</span><span class="code_o">:</span>
                <span class="code_nv">$this</span><span class="code_o">-&gt;</span><span class="code_na">limit_count</span> <span class="code_o">=</span> <span class="code_nv">$value</span><span class="code_p">;</span>
        <span class="code_p">}</span>
    <span class="code_p">}</span></pre></div></td></tr></table></div>]]></content:encoded>
			<dc:creator>Verwijderd</dc:creator>
			<guid isPermaLink="false">https://gathering.tweakers.net/forum/list_message/30107196#30107196</guid>
			<pubDate>Wed, 21 May 2008 15:31:38 GMT</pubDate>
		</item>
		<item>
			<title>Verwijderd</title>
			<link>https://gathering.tweakers.net/forum/list_message/30107184#30107184</link>
			<description>Ik wil best de db class laten zien dat is een standaard PEAR db class
Listing van: DB.php
PHP: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
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
&lt;?php

/* vim: set expandtab tabstop=4 shiftwidth=4 softtabstop=4: */

/**
 * Database independent query interface
 *
 * PHP versions 4 and 5
 *
 * LICENSE: This source file is subject to version 3.0 of the PHP license
 * that is available through the world-wide-web at the following URI:
 * http://www.php.net/license/3_0.txt.  If you did not receive a copy of
 * the PHP License and are unable to obtain it through the web, please
 * send a note to license@php.net so we can mail you a copy immediately.
 *
 * @category   Database
 * @package    DB
 * @author     Stig Bakken &lt;ssb@php.net&gt;
 * @author     Tomas V.V.Cox &lt;cox@idecnet.com&gt;
 * @author     Daniel Convissor &lt;danielc@php.net&gt;
 * @copyright  1997-2005 The PHP Group
 * @license    http://www.php.net/license/3_0.txt  PHP License 3.0
 * @version    CVS: $Id: DB.php,v 1.80 2005/02/16 02:16:00 danielc Exp $
 * @link       http://pear.php.net/package/DB
 */

/**
 * Obtain the PEAR class so it can be extended from
 */
require_once &#039;PEAR.php&#039;;


// {{{ constants
// {{{ error codes

/**#@+
 * One of PEAR DB&#039;s portable error codes.
 * @see DB_common::errorCode(), DB::errorMessage()
 *
 * {@internal If you add an error code here, make sure you also add a textual
 * version of it in DB::errorMessage().}}
 */

/**
 * The code returned by many methods upon success
 */
define(&#039;DB_OK&#039;, 1);

/**
 * Unkown error
 */
define(&#039;DB_ERROR&#039;, -1);

/**
 * Syntax error
 */
define(&#039;DB_ERROR_SYNTAX&#039;, -2);

/**
 * Tried to insert a duplicate value into a primary or unique index
 */
define(&#039;DB_ERROR_CONSTRAINT&#039;, -3);

/**
 * An identifier in the query refers to a non-existant object
 */
define(&#039;DB_ERROR_NOT_FOUND&#039;, -4);

/**
 * Tried to create a duplicate object
 */
define(&#039;DB_ERROR_ALREADY_EXISTS&#039;, -5);

/**
 * The current driver does not support the action you attempted
 */
define(&#039;DB_ERROR_UNSUPPORTED&#039;, -6);

/**
 * The number of parameters does not match the number of placeholders
 */
define(&#039;DB_ERROR_MISMATCH&#039;, -7);

/**
 * A literal submitted did not match the data type expected
 */
define(&#039;DB_ERROR_INVALID&#039;, -8);

/**
 * The current DBMS does not support the action you attempted
 */
define(&#039;DB_ERROR_NOT_CAPABLE&#039;, -9);

/**
 * A literal submitted was too long so the end of it was removed
 */
define(&#039;DB_ERROR_TRUNCATED&#039;, -10);

/**
 * A literal number submitted did not match the data type expected
 */
define(&#039;DB_ERROR_INVALID_NUMBER&#039;, -11);

/**
 * A literal date submitted did not match the data type expected
 */
define(&#039;DB_ERROR_INVALID_DATE&#039;, -12);

/**
 * Attempt to divide something by zero
 */
define(&#039;DB_ERROR_DIVZERO&#039;, -13);

/**
 * A database needs to be selected
 */
define(&#039;DB_ERROR_NODBSELECTED&#039;, -14);

/**
 * Could not create the object requested
 */
define(&#039;DB_ERROR_CANNOT_CREATE&#039;, -15);

/**
 * Could not drop the database requested because it does not exist
 */
define(&#039;DB_ERROR_CANNOT_DROP&#039;, -17);

/**
 * An identifier in the query refers to a non-existant table
 */
define(&#039;DB_ERROR_NOSUCHTABLE&#039;, -18);

/**
 * An identifier in the query refers to a non-existant column
 */
define(&#039;DB_ERROR_NOSUCHFIELD&#039;, -19);

/**
 * The data submitted to the method was inappropriate
 */
define(&#039;DB_ERROR_NEED_MORE_DATA&#039;, -20);

/**
 * The attempt to lock the table failed
 */
define(&#039;DB_ERROR_NOT_LOCKED&#039;, -21);

/**
 * The number of columns doesn&#039;t match the number of values
 */
define(&#039;DB_ERROR_VALUE_COUNT_ON_ROW&#039;, -22);

/**
 * The DSN submitted has problems
 */
define(&#039;DB_ERROR_INVALID_DSN&#039;, -23);

/**
 * Could not connect to the database
 */
define(&#039;DB_ERROR_CONNECT_FAILED&#039;, -24);

/**
 * The PHP extension needed for this DBMS could not be found
 */
define(&#039;DB_ERROR_EXTENSION_NOT_FOUND&#039;,-25);

/**
 * The present user has inadequate permissions to perform the task requestd
 */
define(&#039;DB_ERROR_ACCESS_VIOLATION&#039;, -26);

/**
 * The database requested does not exist
 */
define(&#039;DB_ERROR_NOSUCHDB&#039;, -27);

/**
 * Tried to insert a null value into a column that doesn&#039;t allow nulls
 */
define(&#039;DB_ERROR_CONSTRAINT_NOT_NULL&#039;,-29);
/**#@-*/


// }}}
// {{{ prepared statement-related


/**#@+
 * Identifiers for the placeholders used in prepared statements.
 * @see DB_common::prepare()
 */

/**
 * Indicates a scalar (&lt;kbd&gt;?&lt;/kbd&gt;) placeholder was used
 *
 * Quote and escape the value as necessary.
 */
define(&#039;DB_PARAM_SCALAR&#039;, 1);

/**
 * Indicates an opaque (&lt;kbd&gt;&amp;&lt;/kbd&gt;) placeholder was used
 *
 * The value presented is a file name.  Extract the contents of that file
 * and place them in this column.
 */
define(&#039;DB_PARAM_OPAQUE&#039;, 2);

/**
 * Indicates a misc (&lt;kbd&gt;!&lt;/kbd&gt;) placeholder was used
 *
 * The value should not be quoted or escaped.
 */
define(&#039;DB_PARAM_MISC&#039;,   3);
/**#@-*/


// }}}
// {{{ binary data-related


/**#@+
 * The different ways of returning binary data from queries.
 */

/**
 * Sends the fetched data straight through to output
 */
define(&#039;DB_BINMODE_PASSTHRU&#039;, 1);

/**
 * Lets you return data as usual
 */
define(&#039;DB_BINMODE_RETURN&#039;, 2);

/**
 * Converts the data to hex format before returning it
 *
 * For example the string &quot;123&quot; would become &quot;313233&quot;.
 */
define(&#039;DB_BINMODE_CONVERT&#039;, 3);
/**#@-*/


// }}}
// {{{ fetch modes


/**#@+
 * Fetch Modes.
 * @see DB_common::setFetchMode()
 */

/**
 * Indicates the current default fetch mode should be used
 * @see DB_common::$fetchmode
 */
define(&#039;DB_FETCHMODE_DEFAULT&#039;, 0);

/**
 * Column data indexed by numbers, ordered from 0 and up
 */
define(&#039;DB_FETCHMODE_ORDERED&#039;, 1);

/**
 * Column data indexed by column names
 */
define(&#039;DB_FETCHMODE_ASSOC&#039;, 2);

/**
 * Column data as object properties
 */
define(&#039;DB_FETCHMODE_OBJECT&#039;, 3);

/**
 * For multi-dimensional results, make the column name the first level
 * of the array and put the row number in the second level of the array
 *
 * This is flipped from the normal behavior, which puts the row numbers
 * in the first level of the array and the column names in the second level.
 */
define(&#039;DB_FETCHMODE_FLIPPED&#039;, 4);
/**#@-*/

/**#@+
 * Old fetch modes.  Left here for compatibility.
 */
define(&#039;DB_GETMODE_ORDERED&#039;, DB_FETCHMODE_ORDERED);
define(&#039;DB_GETMODE_ASSOC&#039;,   DB_FETCHMODE_ASSOC);
define(&#039;DB_GETMODE_FLIPPED&#039;, DB_FETCHMODE_FLIPPED);
/**#@-*/


// }}}
// {{{ tableInfo() &amp;&amp; autoPrepare()-related


/**#@+
 * The type of information to return from the tableInfo() method.
 *
 * Bitwised constants, so they can be combined using &lt;kbd&gt;|&lt;/kbd&gt;
 * and removed using &lt;kbd&gt;^&lt;/kbd&gt;.
 *
 * @see DB_common::tableInfo()
 *
 * {@internal Since the TABLEINFO constants are bitwised, if more of them are
 * added in the future, make sure to adjust DB_TABLEINFO_FULL accordingly.}}
 */
define(&#039;DB_TABLEINFO_ORDER&#039;, 1);
define(&#039;DB_TABLEINFO_ORDERTABLE&#039;, 2);
define(&#039;DB_TABLEINFO_FULL&#039;, 3);
/**#@-*/


/**#@+
 * The type of query to create with the automatic query building methods.
 * @see DB_common::autoPrepare(), DB_common::autoExecute()
 */
define(&#039;DB_AUTOQUERY_INSERT&#039;, 1);
define(&#039;DB_AUTOQUERY_UPDATE&#039;, 2);
/**#@-*/


// }}}
// {{{ portability modes


/**#@+
 * Portability Modes.
 *
 * Bitwised constants, so they can be combined using &lt;kbd&gt;|&lt;/kbd&gt;
 * and removed using &lt;kbd&gt;^&lt;/kbd&gt;.
 *
 * @see DB_common::setOption()
 *
 * {@internal Since the PORTABILITY constants are bitwised, if more of them are
 * added in the future, make sure to adjust DB_PORTABILITY_ALL accordingly.}}
 */

/**
 * Turn off all portability features
 */
define(&#039;DB_PORTABILITY_NONE&#039;, 0);

/**
 * Convert names of tables and fields to lower case
 * when using the get*(), fetch*() and tableInfo() methods
 */
define(&#039;DB_PORTABILITY_LOWERCASE&#039;, 1);

/**
 * Right trim the data output by get*() and fetch*()
 */
define(&#039;DB_PORTABILITY_RTRIM&#039;, 2);

/**
 * Force reporting the number of rows deleted
 */
define(&#039;DB_PORTABILITY_DELETE_COUNT&#039;, 4);

/**
 * Enable hack that makes numRows() work in Oracle
 */
define(&#039;DB_PORTABILITY_NUMROWS&#039;, 8);

/**
 * Makes certain error messages in certain drivers compatible
 * with those from other DBMS&#039;s
 *
 * + mysql, mysqli:  change unique/primary key constraints
 *   DB_ERROR_ALREADY_EXISTS -&gt; DB_ERROR_CONSTRAINT
 *
 * + odbc(access):  MS&#039;s ODBC driver reports &#039;no such field&#039; as code
 *   07001, which means &#039;too few parameters.&#039;  When this option is on
 *   that code gets mapped to DB_ERROR_NOSUCHFIELD.
 */
define(&#039;DB_PORTABILITY_ERRORS&#039;, 16);

/**
 * Convert null values to empty strings in data output by
 * get*() and fetch*()
 */
define(&#039;DB_PORTABILITY_NULL_TO_EMPTY&#039;, 32);

/**
 * Turn on all portability features
 */
define(&#039;DB_PORTABILITY_ALL&#039;, 63);
/**#@-*/

// }}}


// }}}
// {{{ class DB

/**
 * Database independent query interface
 *
 * The main &quot;DB&quot; class is simply a container class with some static
 * methods for creating DB objects as well as some utility functions
 * common to all parts of DB.
 *
 * The object model of DB is as follows (indentation means inheritance):
 * &lt;pre&gt;
 * DB           The main DB class.  This is simply a utility class
 *              with some &quot;static&quot; methods for creating DB objects as
 *              well as common utility functions for other DB classes.
 *
 * DB_common    The base for each DB implementation.  Provides default
 * |            implementations (in OO lingo virtual methods) for
 * |            the actual DB implementations as well as a bunch of
 * |            query utility functions.
 * |
 * +-DB_mysql   The DB implementation for MySQL.  Inherits DB_common.
 *              When calling DB::factory or DB::connect for MySQL
 *              connections, the object returned is an instance of this
 *              class.
 * &lt;/pre&gt;
 *
 * @category   Database
 * @package    DB
 * @author     Stig Bakken &lt;ssb@php.net&gt;
 * @author     Tomas V.V.Cox &lt;cox@idecnet.com&gt;
 * @author     Daniel Convissor &lt;danielc@php.net&gt;
 * @copyright  1997-2005 The PHP Group
 * @license    http://www.php.net/license/3_0.txt  PHP License 3.0
 * @version    Release: 1.7.6
 * @link       http://pear.php.net/package/DB
 */
class DB
{
    // {{{ &amp;factory()

    /**
     * Create a new DB object for the specified database type but don&#039;t
     * connect to the database
     *
     * @param string $type     the database type (eg &quot;mysql&quot;)
     * @param array  $options  an associative array of option names and values
     *
     * @return object  a new DB object.  A DB_Error object on failure.
     *
     * @see DB_common::setOption()
     */
    function &amp;factory($type, $options = false)
    {
        if (!is_array($options)) {
            $options = array(&#039;persistent&#039; =&gt; $options);
        }

        if (isset($options[&#039;debug&#039;]) &amp;&amp; $options[&#039;debug&#039;] &gt;= 2) {
            // expose php errors with sufficient debug level
            include_once &quot;DB/{$type}.php&quot;;
        } else {
            @include_once &quot;DB/{$type}.php&quot;;
        }

        $classname = &quot;DB_${type}&quot;;

        if (!class_exists($classname)) {
            $tmp = PEAR::raiseError(null, DB_ERROR_NOT_FOUND, null, null,
                                    &quot;Unable to include the DB/{$type}.php&quot;
                                    . &quot; file for &#039;$dsn&#039;&quot;,
                                    &#039;DB_Error&#039;, true);
            return $tmp;
        }

        @$obj =&amp; new $classname;

        foreach ($options as $option =&gt; $value) {
            $test = $obj-&gt;setOption($option, $value);
            if (DB::isError($test)) {
                return $test;
            }
        }

        return $obj;
    }

    // }}}
    // {{{ &amp;connect()

    /**
     * Create a new DB object including a connection to the specified database
     *
     * Example 1.
     * &lt;code&gt;
     * require_once &#039;DB.php&#039;;
     *
     * $dsn = &#039;pgsql://user:password@host/database&#039;;
     * $options = array(
     *     &#039;debug&#039;       =&gt; 2,
     *     &#039;portability&#039; =&gt; DB_PORTABILITY_ALL,
     * );
     *
     * $db =&amp; DB::connect($dsn, $options);
     * if (PEAR::isError($db)) {
     *     die($db-&gt;getMessage());
     * }
     * &lt;/code&gt;
     *
     * @param mixed $dsn      the string &quot;data source name&quot; or array in the
     *                         format returned by DB::parseDSN()
     * @param array $options  an associative array of option names and values
     *
     * @return object  a new DB object.  A DB_Error object on failure.
     *
     * @uses DB_dbase::connect(), DB_fbsql::connect(), DB_ibase::connect(),
     *       DB_ifx::connect(), DB_msql::connect(), DB_mssql::connect(),
     *       DB_mysql::connect(), DB_mysqli::connect(), DB_oci8::connect(),
     *       DB_odbc::connect(), DB_pgsql::connect(), DB_sqlite::connect(),
     *       DB_sybase::connect()
     *
     * @uses DB::parseDSN(), DB_common::setOption(), PEAR::isError()
     */
    function &amp;connect($dsn, $options = array())
    {
        $dsninfo = DB::parseDSN($dsn);
        $type = $dsninfo[&#039;phptype&#039;];

        if (!is_array($options)) {
            /*
             * For backwards compatibility.  $options used to be boolean,
             * indicating whether the connection should be persistent.
             */
            $options = array(&#039;persistent&#039; =&gt; $options);
        }

        if (isset($options[&#039;debug&#039;]) &amp;&amp; $options[&#039;debug&#039;] &gt;= 2) {
            // expose php errors with sufficient debug level
            include_once &quot;DB/${type}.php&quot;;
        } else {
            @include_once &quot;DB/${type}.php&quot;;
        }

        $classname = &quot;DB_${type}&quot;;
        if (!class_exists($classname)) {
            $tmp = PEAR::raiseError(null, DB_ERROR_NOT_FOUND, null, null,
                                    &quot;Unable to include the DB/{$type}.php&quot;
                                    . &quot; file for &#039;$dsn&#039;&quot;,
                                    &#039;DB_Error&#039;, true);
            return $tmp;
        }

        @$obj =&amp; new $classname;

        foreach ($options as $option =&gt; $value) {
            $test = $obj-&gt;setOption($option, $value);
            if (DB::isError($test)) {
                return $test;
            }
        }

        $err = $obj-&gt;connect($dsninfo, $obj-&gt;getOption(&#039;persistent&#039;));
        if (DB::isError($err)) {
            $err-&gt;addUserInfo($dsn);
            return $err;
        }

        return $obj;
    }

    // }}}
    // {{{ apiVersion()

    /**
     * Return the DB API version
     *
     * @return string  the DB API version number
     */
    function apiVersion()
    {
        return &#039;1.7.6&#039;;
    }

    // }}}
    // {{{ isError()

    /**
     * Determines if a variable is a DB_Error object
     *
     * @param mixed $value  the variable to check
     *
     * @return bool  whether $value is DB_Error object
     */
    function isError($value)
    {
        return is_a($value, &#039;DB_Error&#039;);
    }

    // }}}
    // {{{ isConnection()

    /**
     * Determines if a value is a DB_&lt;driver&gt; object
     *
     * @param mixed $value  the value to test
     *
     * @return bool  whether $value is a DB_&lt;driver&gt; object
     */
    function isConnection($value)
    {
        return (is_object($value) &amp;&amp;
                is_subclass_of($value, &#039;db_common&#039;) &amp;&amp;
                method_exists($value, &#039;simpleQuery&#039;));
    }

    // }}}
    // {{{ isManip()

    /**
     * Tell whether a query is a data manipulation or data definition query
     *
     * Examples of data manipulation queries are INSERT, UPDATE and DELETE.
     * Examples of data definition queries are CREATE, DROP, ALTER, GRANT,
     * REVOKE.
     *
     * @param string $query  the query
     *
     * @return boolean  whether $query is a data manipulation query
     */
    function isManip($query)
    {
        $manips = &#039;INSERT|UPDATE|DELETE|REPLACE|&#039;
                . &#039;CREATE|DROP|&#039;
                . &#039;LOAD DATA|SELECT .* INTO|COPY|&#039;
                . &#039;ALTER|GRANT|REVOKE|&#039;
                . &#039;LOCK|UNLOCK&#039;;
        if (preg_match(&#039;/^\s*&quot;?(&#039; . $manips . &#039;)\s+/i&#039;, $query)) {
            return true;
        }
        return false;
    }

    // }}}
    // {{{ errorMessage()</description>
			<content:encoded><![CDATA[Ik wil best de db class laten zien dat is een standaard PEAR db class<br>
Listing van: DB.php<br>
<div class="code">PHP:<br><table class="phphighlight"><tr><td class="phphighlightline"><pre>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
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
</pre></td><td class="phphighlightcode"><div><pre><span class="code_cp">&lt;?php</span>

<span class="code_cm">/* vim: set expandtab tabstop=4 shiftwidth=4 softtabstop=4: */</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * Database independent query interface</span>
<span class="code_sd"> *</span>
<span class="code_sd"> * PHP versions 4 and 5</span>
<span class="code_sd"> *</span>
<span class="code_sd"> * LICENSE: This source file is subject to version 3.0 of the PHP license</span>
<span class="code_sd"> * that is available through the world-wide-web at the following URI:</span>
<span class="code_sd"> * http://www.php.net/license/3_0.txt.  If you did not receive a copy of</span>
<span class="code_sd"> * the PHP License and are unable to obtain it through the web, please</span>
<span class="code_sd"> * send a note to license@php.net so we can mail you a copy immediately.</span>
<span class="code_sd"> *</span>
<span class="code_sd"> * @category   Database</span>
<span class="code_sd"> * @package    DB</span>
<span class="code_sd"> * @author     Stig Bakken &lt;ssb@php.net&gt;</span>
<span class="code_sd"> * @author     Tomas V.V.Cox &lt;cox@idecnet.com&gt;</span>
<span class="code_sd"> * @author     Daniel Convissor &lt;danielc@php.net&gt;</span>
<span class="code_sd"> * @copyright  1997-2005 The PHP Group</span>
<span class="code_sd"> * @license    http://www.php.net/license/3_0.txt  PHP License 3.0</span>
<span class="code_sd"> * @version    CVS: $Id: DB.php,v 1.80 2005/02/16 02:16:00 danielc Exp $</span>
<span class="code_sd"> * @link       http://pear.php.net/package/DB</span>
<span class="code_sd"> */</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * Obtain the PEAR class so it can be extended from</span>
<span class="code_sd"> */</span>
<span class="code_k">require_once</span> <span class="code_s1">&#39;PEAR.php&#39;</span><span class="code_p">;</span>


<span class="code_c1">// {{{ constants</span>
<span class="code_c1">// {{{ error codes</span>

<span class="code_sd">/**#@+</span>
<span class="code_sd"> * One of PEAR DB&#39;s portable error codes.</span>
<span class="code_sd"> * @see DB_common::errorCode(), DB::errorMessage()</span>
<span class="code_sd"> *</span>
<span class="code_sd"> * {@internal If you add an error code here, make sure you also add a textual</span>
<span class="code_sd"> * version of it in DB::errorMessage().}}</span>
<span class="code_sd"> */</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * The code returned by many methods upon success</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_OK&#39;</span><span class="code_p">,</span> <span class="code_mi">1</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * Unkown error</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_ERROR&#39;</span><span class="code_p">,</span> <span class="code_o">-</span><span class="code_mi">1</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * Syntax error</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_ERROR_SYNTAX&#39;</span><span class="code_p">,</span> <span class="code_o">-</span><span class="code_mi">2</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * Tried to insert a duplicate value into a primary or unique index</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_ERROR_CONSTRAINT&#39;</span><span class="code_p">,</span> <span class="code_o">-</span><span class="code_mi">3</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * An identifier in the query refers to a non-existant object</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_ERROR_NOT_FOUND&#39;</span><span class="code_p">,</span> <span class="code_o">-</span><span class="code_mi">4</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * Tried to create a duplicate object</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_ERROR_ALREADY_EXISTS&#39;</span><span class="code_p">,</span> <span class="code_o">-</span><span class="code_mi">5</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * The current driver does not support the action you attempted</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_ERROR_UNSUPPORTED&#39;</span><span class="code_p">,</span> <span class="code_o">-</span><span class="code_mi">6</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * The number of parameters does not match the number of placeholders</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_ERROR_MISMATCH&#39;</span><span class="code_p">,</span> <span class="code_o">-</span><span class="code_mi">7</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * A literal submitted did not match the data type expected</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_ERROR_INVALID&#39;</span><span class="code_p">,</span> <span class="code_o">-</span><span class="code_mi">8</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * The current DBMS does not support the action you attempted</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_ERROR_NOT_CAPABLE&#39;</span><span class="code_p">,</span> <span class="code_o">-</span><span class="code_mi">9</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * A literal submitted was too long so the end of it was removed</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_ERROR_TRUNCATED&#39;</span><span class="code_p">,</span> <span class="code_o">-</span><span class="code_mi">10</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * A literal number submitted did not match the data type expected</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_ERROR_INVALID_NUMBER&#39;</span><span class="code_p">,</span> <span class="code_o">-</span><span class="code_mi">11</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * A literal date submitted did not match the data type expected</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_ERROR_INVALID_DATE&#39;</span><span class="code_p">,</span> <span class="code_o">-</span><span class="code_mi">12</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * Attempt to divide something by zero</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_ERROR_DIVZERO&#39;</span><span class="code_p">,</span> <span class="code_o">-</span><span class="code_mi">13</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * A database needs to be selected</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_ERROR_NODBSELECTED&#39;</span><span class="code_p">,</span> <span class="code_o">-</span><span class="code_mi">14</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * Could not create the object requested</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_ERROR_CANNOT_CREATE&#39;</span><span class="code_p">,</span> <span class="code_o">-</span><span class="code_mi">15</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * Could not drop the database requested because it does not exist</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_ERROR_CANNOT_DROP&#39;</span><span class="code_p">,</span> <span class="code_o">-</span><span class="code_mi">17</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * An identifier in the query refers to a non-existant table</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_ERROR_NOSUCHTABLE&#39;</span><span class="code_p">,</span> <span class="code_o">-</span><span class="code_mi">18</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * An identifier in the query refers to a non-existant column</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_ERROR_NOSUCHFIELD&#39;</span><span class="code_p">,</span> <span class="code_o">-</span><span class="code_mi">19</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * The data submitted to the method was inappropriate</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_ERROR_NEED_MORE_DATA&#39;</span><span class="code_p">,</span> <span class="code_o">-</span><span class="code_mi">20</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * The attempt to lock the table failed</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_ERROR_NOT_LOCKED&#39;</span><span class="code_p">,</span> <span class="code_o">-</span><span class="code_mi">21</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * The number of columns doesn&#39;t match the number of values</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_ERROR_VALUE_COUNT_ON_ROW&#39;</span><span class="code_p">,</span> <span class="code_o">-</span><span class="code_mi">22</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * The DSN submitted has problems</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_ERROR_INVALID_DSN&#39;</span><span class="code_p">,</span> <span class="code_o">-</span><span class="code_mi">23</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * Could not connect to the database</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_ERROR_CONNECT_FAILED&#39;</span><span class="code_p">,</span> <span class="code_o">-</span><span class="code_mi">24</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * The PHP extension needed for this DBMS could not be found</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_ERROR_EXTENSION_NOT_FOUND&#39;</span><span class="code_p">,</span><span class="code_o">-</span><span class="code_mi">25</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * The present user has inadequate permissions to perform the task requestd</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_ERROR_ACCESS_VIOLATION&#39;</span><span class="code_p">,</span> <span class="code_o">-</span><span class="code_mi">26</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * The database requested does not exist</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_ERROR_NOSUCHDB&#39;</span><span class="code_p">,</span> <span class="code_o">-</span><span class="code_mi">27</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * Tried to insert a null value into a column that doesn&#39;t allow nulls</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_ERROR_CONSTRAINT_NOT_NULL&#39;</span><span class="code_p">,</span><span class="code_o">-</span><span class="code_mi">29</span><span class="code_p">);</span>
<span class="code_sd">/**#@-*/</span>


<span class="code_c1">// }}}</span>
<span class="code_c1">// {{{ prepared statement-related</span>


<span class="code_sd">/**#@+</span>
<span class="code_sd"> * Identifiers for the placeholders used in prepared statements.</span>
<span class="code_sd"> * @see DB_common::prepare()</span>
<span class="code_sd"> */</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * Indicates a scalar (&lt;kbd&gt;?&lt;/kbd&gt;) placeholder was used</span>
<span class="code_sd"> *</span>
<span class="code_sd"> * Quote and escape the value as necessary.</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_PARAM_SCALAR&#39;</span><span class="code_p">,</span> <span class="code_mi">1</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * Indicates an opaque (&lt;kbd&gt;&amp;&lt;/kbd&gt;) placeholder was used</span>
<span class="code_sd"> *</span>
<span class="code_sd"> * The value presented is a file name.  Extract the contents of that file</span>
<span class="code_sd"> * and place them in this column.</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_PARAM_OPAQUE&#39;</span><span class="code_p">,</span> <span class="code_mi">2</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * Indicates a misc (&lt;kbd&gt;!&lt;/kbd&gt;) placeholder was used</span>
<span class="code_sd"> *</span>
<span class="code_sd"> * The value should not be quoted or escaped.</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_PARAM_MISC&#39;</span><span class="code_p">,</span>   <span class="code_mi">3</span><span class="code_p">);</span>
<span class="code_sd">/**#@-*/</span>


<span class="code_c1">// }}}</span>
<span class="code_c1">// {{{ binary data-related</span>


<span class="code_sd">/**#@+</span>
<span class="code_sd"> * The different ways of returning binary data from queries.</span>
<span class="code_sd"> */</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * Sends the fetched data straight through to output</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_BINMODE_PASSTHRU&#39;</span><span class="code_p">,</span> <span class="code_mi">1</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * Lets you return data as usual</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_BINMODE_RETURN&#39;</span><span class="code_p">,</span> <span class="code_mi">2</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * Converts the data to hex format before returning it</span>
<span class="code_sd"> *</span>
<span class="code_sd"> * For example the string &quot;123&quot; would become &quot;313233&quot;.</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_BINMODE_CONVERT&#39;</span><span class="code_p">,</span> <span class="code_mi">3</span><span class="code_p">);</span>
<span class="code_sd">/**#@-*/</span>


<span class="code_c1">// }}}</span>
<span class="code_c1">// {{{ fetch modes</span>


<span class="code_sd">/**#@+</span>
<span class="code_sd"> * Fetch Modes.</span>
<span class="code_sd"> * @see DB_common::setFetchMode()</span>
<span class="code_sd"> */</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * Indicates the current default fetch mode should be used</span>
<span class="code_sd"> * @see DB_common::$fetchmode</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_FETCHMODE_DEFAULT&#39;</span><span class="code_p">,</span> <span class="code_mi">0</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * Column data indexed by numbers, ordered from 0 and up</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_FETCHMODE_ORDERED&#39;</span><span class="code_p">,</span> <span class="code_mi">1</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * Column data indexed by column names</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_FETCHMODE_ASSOC&#39;</span><span class="code_p">,</span> <span class="code_mi">2</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * Column data as object properties</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_FETCHMODE_OBJECT&#39;</span><span class="code_p">,</span> <span class="code_mi">3</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * For multi-dimensional results, make the column name the first level</span>
<span class="code_sd"> * of the array and put the row number in the second level of the array</span>
<span class="code_sd"> *</span>
<span class="code_sd"> * This is flipped from the normal behavior, which puts the row numbers</span>
<span class="code_sd"> * in the first level of the array and the column names in the second level.</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_FETCHMODE_FLIPPED&#39;</span><span class="code_p">,</span> <span class="code_mi">4</span><span class="code_p">);</span>
<span class="code_sd">/**#@-*/</span>

<span class="code_sd">/**#@+</span>
<span class="code_sd"> * Old fetch modes.  Left here for compatibility.</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_GETMODE_ORDERED&#39;</span><span class="code_p">,</span> <span class="code_nx">DB_FETCHMODE_ORDERED</span><span class="code_p">);</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_GETMODE_ASSOC&#39;</span><span class="code_p">,</span>   <span class="code_nx">DB_FETCHMODE_ASSOC</span><span class="code_p">);</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_GETMODE_FLIPPED&#39;</span><span class="code_p">,</span> <span class="code_nx">DB_FETCHMODE_FLIPPED</span><span class="code_p">);</span>
<span class="code_sd">/**#@-*/</span>


<span class="code_c1">// }}}</span>
<span class="code_c1">// {{{ tableInfo() &amp;&amp; autoPrepare()-related</span>


<span class="code_sd">/**#@+</span>
<span class="code_sd"> * The type of information to return from the tableInfo() method.</span>
<span class="code_sd"> *</span>
<span class="code_sd"> * Bitwised constants, so they can be combined using &lt;kbd&gt;|&lt;/kbd&gt;</span>
<span class="code_sd"> * and removed using &lt;kbd&gt;^&lt;/kbd&gt;.</span>
<span class="code_sd"> *</span>
<span class="code_sd"> * @see DB_common::tableInfo()</span>
<span class="code_sd"> *</span>
<span class="code_sd"> * {@internal Since the TABLEINFO constants are bitwised, if more of them are</span>
<span class="code_sd"> * added in the future, make sure to adjust DB_TABLEINFO_FULL accordingly.}}</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_TABLEINFO_ORDER&#39;</span><span class="code_p">,</span> <span class="code_mi">1</span><span class="code_p">);</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_TABLEINFO_ORDERTABLE&#39;</span><span class="code_p">,</span> <span class="code_mi">2</span><span class="code_p">);</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_TABLEINFO_FULL&#39;</span><span class="code_p">,</span> <span class="code_mi">3</span><span class="code_p">);</span>
<span class="code_sd">/**#@-*/</span>


<span class="code_sd">/**#@+</span>
<span class="code_sd"> * The type of query to create with the automatic query building methods.</span>
<span class="code_sd"> * @see DB_common::autoPrepare(), DB_common::autoExecute()</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_AUTOQUERY_INSERT&#39;</span><span class="code_p">,</span> <span class="code_mi">1</span><span class="code_p">);</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_AUTOQUERY_UPDATE&#39;</span><span class="code_p">,</span> <span class="code_mi">2</span><span class="code_p">);</span>
<span class="code_sd">/**#@-*/</span>


<span class="code_c1">// }}}</span>
<span class="code_c1">// {{{ portability modes</span>


<span class="code_sd">/**#@+</span>
<span class="code_sd"> * Portability Modes.</span>
<span class="code_sd"> *</span>
<span class="code_sd"> * Bitwised constants, so they can be combined using &lt;kbd&gt;|&lt;/kbd&gt;</span>
<span class="code_sd"> * and removed using &lt;kbd&gt;^&lt;/kbd&gt;.</span>
<span class="code_sd"> *</span>
<span class="code_sd"> * @see DB_common::setOption()</span>
<span class="code_sd"> *</span>
<span class="code_sd"> * {@internal Since the PORTABILITY constants are bitwised, if more of them are</span>
<span class="code_sd"> * added in the future, make sure to adjust DB_PORTABILITY_ALL accordingly.}}</span>
<span class="code_sd"> */</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * Turn off all portability features</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_PORTABILITY_NONE&#39;</span><span class="code_p">,</span> <span class="code_mi">0</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * Convert names of tables and fields to lower case</span>
<span class="code_sd"> * when using the get*(), fetch*() and tableInfo() methods</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_PORTABILITY_LOWERCASE&#39;</span><span class="code_p">,</span> <span class="code_mi">1</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * Right trim the data output by get*() and fetch*()</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_PORTABILITY_RTRIM&#39;</span><span class="code_p">,</span> <span class="code_mi">2</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * Force reporting the number of rows deleted</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_PORTABILITY_DELETE_COUNT&#39;</span><span class="code_p">,</span> <span class="code_mi">4</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * Enable hack that makes numRows() work in Oracle</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_PORTABILITY_NUMROWS&#39;</span><span class="code_p">,</span> <span class="code_mi">8</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * Makes certain error messages in certain drivers compatible</span>
<span class="code_sd"> * with those from other DBMS&#39;s</span>
<span class="code_sd"> *</span>
<span class="code_sd"> * + mysql, mysqli:  change unique/primary key constraints</span>
<span class="code_sd"> *   DB_ERROR_ALREADY_EXISTS -&gt; DB_ERROR_CONSTRAINT</span>
<span class="code_sd"> *</span>
<span class="code_sd"> * + odbc(access):  MS&#39;s ODBC driver reports &#39;no such field&#39; as code</span>
<span class="code_sd"> *   07001, which means &#39;too few parameters.&#39;  When this option is on</span>
<span class="code_sd"> *   that code gets mapped to DB_ERROR_NOSUCHFIELD.</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_PORTABILITY_ERRORS&#39;</span><span class="code_p">,</span> <span class="code_mi">16</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * Convert null values to empty strings in data output by</span>
<span class="code_sd"> * get*() and fetch*()</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_PORTABILITY_NULL_TO_EMPTY&#39;</span><span class="code_p">,</span> <span class="code_mi">32</span><span class="code_p">);</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * Turn on all portability features</span>
<span class="code_sd"> */</span>
<span class="code_nb">define</span><span class="code_p">(</span><span class="code_s1">&#39;DB_PORTABILITY_ALL&#39;</span><span class="code_p">,</span> <span class="code_mi">63</span><span class="code_p">);</span>
<span class="code_sd">/**#@-*/</span>

<span class="code_c1">// }}}</span>


<span class="code_c1">// }}}</span>
<span class="code_c1">// {{{ class DB</span>

<span class="code_sd">/**</span>
<span class="code_sd"> * Database independent query interface</span>
<span class="code_sd"> *</span>
<span class="code_sd"> * The main &quot;DB&quot; class is simply a container class with some static</span>
<span class="code_sd"> * methods for creating DB objects as well as some utility functions</span>
<span class="code_sd"> * common to all parts of DB.</span>
<span class="code_sd"> *</span>
<span class="code_sd"> * The object model of DB is as follows (indentation means inheritance):</span>
<span class="code_sd"> * &lt;pre&gt;</span>
<span class="code_sd"> * DB           The main DB class.  This is simply a utility class</span>
<span class="code_sd"> *              with some &quot;static&quot; methods for creating DB objects as</span>
<span class="code_sd"> *              well as common utility functions for other DB classes.</span>
<span class="code_sd"> *</span>
<span class="code_sd"> * DB_common    The base for each DB implementation.  Provides default</span>
<span class="code_sd"> * |            implementations (in OO lingo virtual methods) for</span>
<span class="code_sd"> * |            the actual DB implementations as well as a bunch of</span>
<span class="code_sd"> * |            query utility functions.</span>
<span class="code_sd"> * |</span>
<span class="code_sd"> * +-DB_mysql   The DB implementation for MySQL.  Inherits DB_common.</span>
<span class="code_sd"> *              When calling DB::factory or DB::connect for MySQL</span>
<span class="code_sd"> *              connections, the object returned is an instance of this</span>
<span class="code_sd"> *              class.</span>
<span class="code_sd"> * &lt;/pre&gt;</span>
<span class="code_sd"> *</span>
<span class="code_sd"> * @category   Database</span>
<span class="code_sd"> * @package    DB</span>
<span class="code_sd"> * @author     Stig Bakken &lt;ssb@php.net&gt;</span>
<span class="code_sd"> * @author     Tomas V.V.Cox &lt;cox@idecnet.com&gt;</span>
<span class="code_sd"> * @author     Daniel Convissor &lt;danielc@php.net&gt;</span>
<span class="code_sd"> * @copyright  1997-2005 The PHP Group</span>
<span class="code_sd"> * @license    http://www.php.net/license/3_0.txt  PHP License 3.0</span>
<span class="code_sd"> * @version    Release: 1.7.6</span>
<span class="code_sd"> * @link       http://pear.php.net/package/DB</span>
<span class="code_sd"> */</span>
<span class="code_k">class</span> <span class="code_nc">DB</span>
<span class="code_p">{</span>
    <span class="code_c1">// {{{ &amp;factory()</span>

    <span class="code_sd">/**</span>
<span class="code_sd">     * Create a new DB object for the specified database type but don&#39;t</span>
<span class="code_sd">     * connect to the database</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * @param string $type     the database type (eg &quot;mysql&quot;)</span>
<span class="code_sd">     * @param array  $options  an associative array of option names and values</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * @return object  a new DB object.  A DB_Error object on failure.</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * @see DB_common::setOption()</span>
<span class="code_sd">     */</span>
    <span class="code_k">function</span> <span class="code_o">&amp;</span><span class="code_nf">factory</span><span class="code_p">(</span><span class="code_nv">$type</span><span class="code_p">,</span> <span class="code_nv">$options</span> <span class="code_o">=</span> <span class="code_k">false</span><span class="code_p">)</span>
    <span class="code_p">{</span>
        <span class="code_k">if</span> <span class="code_p">(</span><span class="code_o">!</span><span class="code_nb">is_array</span><span class="code_p">(</span><span class="code_nv">$options</span><span class="code_p">))</span> <span class="code_p">{</span>
            <span class="code_nv">$options</span> <span class="code_o">=</span> <span class="code_k">array</span><span class="code_p">(</span><span class="code_s1">&#39;persistent&#39;</span> <span class="code_o">=&gt;</span> <span class="code_nv">$options</span><span class="code_p">);</span>
        <span class="code_p">}</span>

        <span class="code_k">if</span> <span class="code_p">(</span><span class="code_nb">isset</span><span class="code_p">(</span><span class="code_nv">$options</span><span class="code_p">[</span><span class="code_s1">&#39;debug&#39;</span><span class="code_p">])</span> <span class="code_o">&amp;&amp;</span> <span class="code_nv">$options</span><span class="code_p">[</span><span class="code_s1">&#39;debug&#39;</span><span class="code_p">]</span> <span class="code_o">&gt;=</span> <span class="code_mi">2</span><span class="code_p">)</span> <span class="code_p">{</span>
            <span class="code_c1">// expose php errors with sufficient debug level</span>
            <span class="code_k">include_once</span> <span class="code_s2">&quot;DB/</span><span class="code_si">{</span><span class="code_nv">$type</span><span class="code_si">}</span><span class="code_s2">.php&quot;</span><span class="code_p">;</span>
        <span class="code_p">}</span> <span class="code_k">else</span> <span class="code_p">{</span>
            <span class="code_o">@</span><span class="code_k">include_once</span> <span class="code_s2">&quot;DB/</span><span class="code_si">{</span><span class="code_nv">$type</span><span class="code_si">}</span><span class="code_s2">.php&quot;</span><span class="code_p">;</span>
        <span class="code_p">}</span>

        <span class="code_nv">$classname</span> <span class="code_o">=</span> <span class="code_s2">&quot;DB_</span><span class="code_si">${</span><span class="code_nv">type</span><span class="code_si">}</span><span class="code_s2">&quot;</span><span class="code_p">;</span>

        <span class="code_k">if</span> <span class="code_p">(</span><span class="code_o">!</span><span class="code_nb">class_exists</span><span class="code_p">(</span><span class="code_nv">$classname</span><span class="code_p">))</span> <span class="code_p">{</span>
            <span class="code_nv">$tmp</span> <span class="code_o">=</span> <span class="code_nx">PEAR</span><span class="code_o">::</span><span class="code_na">raiseError</span><span class="code_p">(</span><span class="code_k">null</span><span class="code_p">,</span> <span class="code_nx">DB_ERROR_NOT_FOUND</span><span class="code_p">,</span> <span class="code_k">null</span><span class="code_p">,</span> <span class="code_k">null</span><span class="code_p">,</span>
                                    <span class="code_s2">&quot;Unable to include the DB/</span><span class="code_si">{</span><span class="code_nv">$type</span><span class="code_si">}</span><span class="code_s2">.php&quot;</span>
                                    <span class="code_o">.</span> <span class="code_s2">&quot; file for &#39;</span><span class="code_si">$dsn</span><span class="code_s2">&#39;&quot;</span><span class="code_p">,</span>
                                    <span class="code_s1">&#39;DB_Error&#39;</span><span class="code_p">,</span> <span class="code_k">true</span><span class="code_p">);</span>
            <span class="code_k">return</span> <span class="code_nv">$tmp</span><span class="code_p">;</span>
        <span class="code_p">}</span>

        <span class="code_o">@</span><span class="code_nv">$obj</span> <span class="code_o">=&amp;</span> <span class="code_k">new</span> <span class="code_nv">$classname</span><span class="code_p">;</span>

        <span class="code_k">foreach</span> <span class="code_p">(</span><span class="code_nv">$options</span> <span class="code_k">as</span> <span class="code_nv">$option</span> <span class="code_o">=&gt;</span> <span class="code_nv">$value</span><span class="code_p">)</span> <span class="code_p">{</span>
            <span class="code_nv">$test</span> <span class="code_o">=</span> <span class="code_nv">$obj</span><span class="code_o">-&gt;</span><span class="code_na">setOption</span><span class="code_p">(</span><span class="code_nv">$option</span><span class="code_p">,</span> <span class="code_nv">$value</span><span class="code_p">);</span>
            <span class="code_k">if</span> <span class="code_p">(</span><span class="code_nx">DB</span><span class="code_o">::</span><span class="code_na">isError</span><span class="code_p">(</span><span class="code_nv">$test</span><span class="code_p">))</span> <span class="code_p">{</span>
                <span class="code_k">return</span> <span class="code_nv">$test</span><span class="code_p">;</span>
            <span class="code_p">}</span>
        <span class="code_p">}</span>

        <span class="code_k">return</span> <span class="code_nv">$obj</span><span class="code_p">;</span>
    <span class="code_p">}</span>

    <span class="code_c1">// }}}</span>
    <span class="code_c1">// {{{ &amp;connect()</span>

    <span class="code_sd">/**</span>
<span class="code_sd">     * Create a new DB object including a connection to the specified database</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * Example 1.</span>
<span class="code_sd">     * &lt;code&gt;</span>
<span class="code_sd">     * require_once &#39;DB.php&#39;;</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * $dsn = &#39;pgsql://user:password@host/database&#39;;</span>
<span class="code_sd">     * $options = array(</span>
<span class="code_sd">     *     &#39;debug&#39;       =&gt; 2,</span>
<span class="code_sd">     *     &#39;portability&#39; =&gt; DB_PORTABILITY_ALL,</span>
<span class="code_sd">     * );</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * $db =&amp; DB::connect($dsn, $options);</span>
<span class="code_sd">     * if (PEAR::isError($db)) {</span>
<span class="code_sd">     *     die($db-&gt;getMessage());</span>
<span class="code_sd">     * }</span>
<span class="code_sd">     * &lt;/code&gt;</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * @param mixed $dsn      the string &quot;data source name&quot; or array in the</span>
<span class="code_sd">     *                         format returned by DB::parseDSN()</span>
<span class="code_sd">     * @param array $options  an associative array of option names and values</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * @return object  a new DB object.  A DB_Error object on failure.</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * @uses DB_dbase::connect(), DB_fbsql::connect(), DB_ibase::connect(),</span>
<span class="code_sd">     *       DB_ifx::connect(), DB_msql::connect(), DB_mssql::connect(),</span>
<span class="code_sd">     *       DB_mysql::connect(), DB_mysqli::connect(), DB_oci8::connect(),</span>
<span class="code_sd">     *       DB_odbc::connect(), DB_pgsql::connect(), DB_sqlite::connect(),</span>
<span class="code_sd">     *       DB_sybase::connect()</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * @uses DB::parseDSN(), DB_common::setOption(), PEAR::isError()</span>
<span class="code_sd">     */</span>
    <span class="code_k">function</span> <span class="code_o">&amp;</span><span class="code_nf">connect</span><span class="code_p">(</span><span class="code_nv">$dsn</span><span class="code_p">,</span> <span class="code_nv">$options</span> <span class="code_o">=</span> <span class="code_k">array</span><span class="code_p">())</span>
    <span class="code_p">{</span>
        <span class="code_nv">$dsninfo</span> <span class="code_o">=</span> <span class="code_nx">DB</span><span class="code_o">::</span><span class="code_na">parseDSN</span><span class="code_p">(</span><span class="code_nv">$dsn</span><span class="code_p">);</span>
        <span class="code_nv">$type</span> <span class="code_o">=</span> <span class="code_nv">$dsninfo</span><span class="code_p">[</span><span class="code_s1">&#39;phptype&#39;</span><span class="code_p">];</span>

        <span class="code_k">if</span> <span class="code_p">(</span><span class="code_o">!</span><span class="code_nb">is_array</span><span class="code_p">(</span><span class="code_nv">$options</span><span class="code_p">))</span> <span class="code_p">{</span>
            <span class="code_cm">/*</span>
<span class="code_cm">             * For backwards compatibility.  $options used to be boolean,</span>
<span class="code_cm">             * indicating whether the connection should be persistent.</span>
<span class="code_cm">             */</span>
            <span class="code_nv">$options</span> <span class="code_o">=</span> <span class="code_k">array</span><span class="code_p">(</span><span class="code_s1">&#39;persistent&#39;</span> <span class="code_o">=&gt;</span> <span class="code_nv">$options</span><span class="code_p">);</span>
        <span class="code_p">}</span>

        <span class="code_k">if</span> <span class="code_p">(</span><span class="code_nb">isset</span><span class="code_p">(</span><span class="code_nv">$options</span><span class="code_p">[</span><span class="code_s1">&#39;debug&#39;</span><span class="code_p">])</span> <span class="code_o">&amp;&amp;</span> <span class="code_nv">$options</span><span class="code_p">[</span><span class="code_s1">&#39;debug&#39;</span><span class="code_p">]</span> <span class="code_o">&gt;=</span> <span class="code_mi">2</span><span class="code_p">)</span> <span class="code_p">{</span>
            <span class="code_c1">// expose php errors with sufficient debug level</span>
            <span class="code_k">include_once</span> <span class="code_s2">&quot;DB/</span><span class="code_si">${</span><span class="code_nv">type</span><span class="code_si">}</span><span class="code_s2">.php&quot;</span><span class="code_p">;</span>
        <span class="code_p">}</span> <span class="code_k">else</span> <span class="code_p">{</span>
            <span class="code_o">@</span><span class="code_k">include_once</span> <span class="code_s2">&quot;DB/</span><span class="code_si">${</span><span class="code_nv">type</span><span class="code_si">}</span><span class="code_s2">.php&quot;</span><span class="code_p">;</span>
        <span class="code_p">}</span>

        <span class="code_nv">$classname</span> <span class="code_o">=</span> <span class="code_s2">&quot;DB_</span><span class="code_si">${</span><span class="code_nv">type</span><span class="code_si">}</span><span class="code_s2">&quot;</span><span class="code_p">;</span>
        <span class="code_k">if</span> <span class="code_p">(</span><span class="code_o">!</span><span class="code_nb">class_exists</span><span class="code_p">(</span><span class="code_nv">$classname</span><span class="code_p">))</span> <span class="code_p">{</span>
            <span class="code_nv">$tmp</span> <span class="code_o">=</span> <span class="code_nx">PEAR</span><span class="code_o">::</span><span class="code_na">raiseError</span><span class="code_p">(</span><span class="code_k">null</span><span class="code_p">,</span> <span class="code_nx">DB_ERROR_NOT_FOUND</span><span class="code_p">,</span> <span class="code_k">null</span><span class="code_p">,</span> <span class="code_k">null</span><span class="code_p">,</span>
                                    <span class="code_s2">&quot;Unable to include the DB/</span><span class="code_si">{</span><span class="code_nv">$type</span><span class="code_si">}</span><span class="code_s2">.php&quot;</span>
                                    <span class="code_o">.</span> <span class="code_s2">&quot; file for &#39;</span><span class="code_si">$dsn</span><span class="code_s2">&#39;&quot;</span><span class="code_p">,</span>
                                    <span class="code_s1">&#39;DB_Error&#39;</span><span class="code_p">,</span> <span class="code_k">true</span><span class="code_p">);</span>
            <span class="code_k">return</span> <span class="code_nv">$tmp</span><span class="code_p">;</span>
        <span class="code_p">}</span>

        <span class="code_o">@</span><span class="code_nv">$obj</span> <span class="code_o">=&amp;</span> <span class="code_k">new</span> <span class="code_nv">$classname</span><span class="code_p">;</span>

        <span class="code_k">foreach</span> <span class="code_p">(</span><span class="code_nv">$options</span> <span class="code_k">as</span> <span class="code_nv">$option</span> <span class="code_o">=&gt;</span> <span class="code_nv">$value</span><span class="code_p">)</span> <span class="code_p">{</span>
            <span class="code_nv">$test</span> <span class="code_o">=</span> <span class="code_nv">$obj</span><span class="code_o">-&gt;</span><span class="code_na">setOption</span><span class="code_p">(</span><span class="code_nv">$option</span><span class="code_p">,</span> <span class="code_nv">$value</span><span class="code_p">);</span>
            <span class="code_k">if</span> <span class="code_p">(</span><span class="code_nx">DB</span><span class="code_o">::</span><span class="code_na">isError</span><span class="code_p">(</span><span class="code_nv">$test</span><span class="code_p">))</span> <span class="code_p">{</span>
                <span class="code_k">return</span> <span class="code_nv">$test</span><span class="code_p">;</span>
            <span class="code_p">}</span>
        <span class="code_p">}</span>

        <span class="code_nv">$err</span> <span class="code_o">=</span> <span class="code_nv">$obj</span><span class="code_o">-&gt;</span><span class="code_na">connect</span><span class="code_p">(</span><span class="code_nv">$dsninfo</span><span class="code_p">,</span> <span class="code_nv">$obj</span><span class="code_o">-&gt;</span><span class="code_na">getOption</span><span class="code_p">(</span><span class="code_s1">&#39;persistent&#39;</span><span class="code_p">));</span>
        <span class="code_k">if</span> <span class="code_p">(</span><span class="code_nx">DB</span><span class="code_o">::</span><span class="code_na">isError</span><span class="code_p">(</span><span class="code_nv">$err</span><span class="code_p">))</span> <span class="code_p">{</span>
            <span class="code_nv">$err</span><span class="code_o">-&gt;</span><span class="code_na">addUserInfo</span><span class="code_p">(</span><span class="code_nv">$dsn</span><span class="code_p">);</span>
            <span class="code_k">return</span> <span class="code_nv">$err</span><span class="code_p">;</span>
        <span class="code_p">}</span>

        <span class="code_k">return</span> <span class="code_nv">$obj</span><span class="code_p">;</span>
    <span class="code_p">}</span>

    <span class="code_c1">// }}}</span>
    <span class="code_c1">// {{{ apiVersion()</span>

    <span class="code_sd">/**</span>
<span class="code_sd">     * Return the DB API version</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * @return string  the DB API version number</span>
<span class="code_sd">     */</span>
    <span class="code_k">function</span> <span class="code_nf">apiVersion</span><span class="code_p">()</span>
    <span class="code_p">{</span>
        <span class="code_k">return</span> <span class="code_s1">&#39;1.7.6&#39;</span><span class="code_p">;</span>
    <span class="code_p">}</span>

    <span class="code_c1">// }}}</span>
    <span class="code_c1">// {{{ isError()</span>

    <span class="code_sd">/**</span>
<span class="code_sd">     * Determines if a variable is a DB_Error object</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * @param mixed $value  the variable to check</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * @return bool  whether $value is DB_Error object</span>
<span class="code_sd">     */</span>
    <span class="code_k">function</span> <span class="code_nf">isError</span><span class="code_p">(</span><span class="code_nv">$value</span><span class="code_p">)</span>
    <span class="code_p">{</span>
        <span class="code_k">return</span> <span class="code_nb">is_a</span><span class="code_p">(</span><span class="code_nv">$value</span><span class="code_p">,</span> <span class="code_s1">&#39;DB_Error&#39;</span><span class="code_p">);</span>
    <span class="code_p">}</span>

    <span class="code_c1">// }}}</span>
    <span class="code_c1">// {{{ isConnection()</span>

    <span class="code_sd">/**</span>
<span class="code_sd">     * Determines if a value is a DB_&lt;driver&gt; object</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * @param mixed $value  the value to test</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * @return bool  whether $value is a DB_&lt;driver&gt; object</span>
<span class="code_sd">     */</span>
    <span class="code_k">function</span> <span class="code_nf">isConnection</span><span class="code_p">(</span><span class="code_nv">$value</span><span class="code_p">)</span>
    <span class="code_p">{</span>
        <span class="code_k">return</span> <span class="code_p">(</span><span class="code_nb">is_object</span><span class="code_p">(</span><span class="code_nv">$value</span><span class="code_p">)</span> <span class="code_o">&amp;&amp;</span>
                <span class="code_nb">is_subclass_of</span><span class="code_p">(</span><span class="code_nv">$value</span><span class="code_p">,</span> <span class="code_s1">&#39;db_common&#39;</span><span class="code_p">)</span> <span class="code_o">&amp;&amp;</span>
                <span class="code_nb">method_exists</span><span class="code_p">(</span><span class="code_nv">$value</span><span class="code_p">,</span> <span class="code_s1">&#39;simpleQuery&#39;</span><span class="code_p">));</span>
    <span class="code_p">}</span>

    <span class="code_c1">// }}}</span>
    <span class="code_c1">// {{{ isManip()</span>

    <span class="code_sd">/**</span>
<span class="code_sd">     * Tell whether a query is a data manipulation or data definition query</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * Examples of data manipulation queries are INSERT, UPDATE and DELETE.</span>
<span class="code_sd">     * Examples of data definition queries are CREATE, DROP, ALTER, GRANT,</span>
<span class="code_sd">     * REVOKE.</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * @param string $query  the query</span>
<span class="code_sd">     *</span>
<span class="code_sd">     * @return boolean  whether $query is a data manipulation query</span>
<span class="code_sd">     */</span>
    <span class="code_k">function</span> <span class="code_nf">isManip</span><span class="code_p">(</span><span class="code_nv">$query</span><span class="code_p">)</span>
    <span class="code_p">{</span>
        <span class="code_nv">$manips</span> <span class="code_o">=</span> <span class="code_s1">&#39;INSERT|UPDATE|DELETE|REPLACE|&#39;</span>
                <span class="code_o">.</span> <span class="code_s1">&#39;CREATE|DROP|&#39;</span>
                <span class="code_o">.</span> <span class="code_s1">&#39;LOAD DATA|SELECT .* INTO|COPY|&#39;</span>
                <span class="code_o">.</span> <span class="code_s1">&#39;ALTER|GRANT|REVOKE|&#39;</span>
                <span class="code_o">.</span> <span class="code_s1">&#39;LOCK|UNLOCK&#39;</span><span class="code_p">;</span>
        <span class="code_k">if</span> <span class="code_p">(</span><span class="code_nb">preg_match</span><span class="code_p">(</span><span class="code_s1">&#39;/^\s*&quot;?(&#39;</span> <span class="code_o">.</span> <span class="code_nv">$manips</span> <span class="code_o">.</span> <span class="code_s1">&#39;)\s+/i&#39;</span><span class="code_p">,</span> <span class="code_nv">$query</span><span class="code_p">))</span> <span class="code_p">{</span>
            <span class="code_k">return</span> <span class="code_k">true</span><span class="code_p">;</span>
        <span class="code_p">}</span>
        <span class="code_k">return</span> <span class="code_k">false</span><span class="code_p">;</span>
    <span class="code_p">}</span>

    <span class="code_c1">// }}}</span>
    <span class="code_c1">// {{{ errorMessage()</span></pre></div></td></tr></table></div>]]></content:encoded>
			<dc:creator>Verwijderd</dc:creator>
			<guid isPermaLink="false">https://gathering.tweakers.net/forum/list_message/30107184#30107184</guid>
			<pubDate>Wed, 21 May 2008 15:29:58 GMT</pubDate>
		</item>
		<item>
			<title>BarthezZ</title>
			<link>https://gathering.tweakers.net/forum/list_message/30104981#30104981</link>
			<description>Wat is het verschil in de data dat je bij de ene $dbh2-&gt;getAssoc aanroept bij het assignen en bij de andere $dbh2-&gt;getRow aan een variabel voert? Als je kan, hou je code zo uniform mogelijk.

Zonder de db class te zien kan ik niet zeggen wat er mis gaat in de getAssoc, of überhaupt wat getAssoc moet returnen.</description>
			<content:encoded><![CDATA[Wat is het verschil in de data dat je bij de ene $dbh2-&gt;getAssoc aanroept bij het assignen en bij de andere $dbh2-&gt;getRow aan een variabel voert? Als je kan, hou je code zo uniform mogelijk.<br>
<br>
Zonder de db class te zien kan ik niet zeggen wat er mis gaat in de getAssoc, of überhaupt wat getAssoc moet returnen.]]></content:encoded>
			<dc:creator>BarthezZ</dc:creator>
			<guid isPermaLink="false">https://gathering.tweakers.net/forum/list_message/30104981#30104981</guid>
			<pubDate>Wed, 21 May 2008 10:25:31 GMT</pubDate>
		</item>
		<item>
			<title>Verwijderd</title>
			<link>https://gathering.tweakers.net/forum/list_message/30102807#30102807</link>
			<description>Dat klopt, dit is ook een test nog vandaar, die if-statement kan weg inderdaad maar die wordt later nog aangepast als dit gedeelte werkt. 
Daarom zou hij het nog wel moeten doen toch?</description>
			<content:encoded><![CDATA[Dat klopt, dit is ook een test nog vandaar, die if-statement kan weg inderdaad maar die wordt later nog aangepast als dit gedeelte werkt. <br>
Daarom zou hij het nog wel moeten doen toch?]]></content:encoded>
			<dc:creator>Verwijderd</dc:creator>
			<guid isPermaLink="false">https://gathering.tweakers.net/forum/list_message/30102807#30102807</guid>
			<pubDate>Tue, 20 May 2008 21:23:24 GMT</pubDate>
		</item>
		<item>
			<title>Snake</title>
			<link>https://gathering.tweakers.net/forum/list_message/30102798#30102798</link>
			<description>Ik heb niet alles doorgelezen, maar ik zie wel dit:

PHP:2
if ($bedrijf_id==$bedrijf_id){

Dit is altijd true </description>
			<content:encoded><![CDATA[Ik heb niet alles doorgelezen, maar ik zie wel dit:<br>
<br>
<div class="code">PHP:<br><table class="phphighlight"><tr><td class="phphighlightline"><pre>2
</pre></td><td class="phphighlightcode"><div><pre><span class="code_k">if</span> <span class="code_p">(</span><span class="code_nv">$bedrijf_id</span><span class="code_o">==</span><span class="code_nv">$bedrijf_id</span><span class="code_p">){</span></pre></div></td></tr></table></div><br>
<br>
Dit is altijd true <img src="https://tweakers.net/g/s/confused.svg" width="20" height="16" alt=":?">]]></content:encoded>
			<dc:creator>Snake</dc:creator>
			<guid isPermaLink="false">https://gathering.tweakers.net/forum/list_message/30102798#30102798</guid>
			<pubDate>Tue, 20 May 2008 21:22:12 GMT</pubDate>
		</item>
		<item>
			<title>Verwijderd</title>
			<link>https://gathering.tweakers.net/forum/list_message/30102409#30102409</link>
			<description>Ja zekers anders zou hij ook geen waardes meegeven

ik geef je even een stuk uit het {debug} gedeelte van smarty

{$SCRIPT_NAME} /home/home.php 

{$bedrijf_id} 27 

{$categorie2} Array (13)
93 =&gt; Air
94 =&gt; airia
67 =&gt; Assortiment
72 =&gt; Dummies|Tijdelijk
4 =&gt; Flush
61 =&gt; Home electricals
63 =&gt; Home others/Instant Car
64 =&gt; Home others/Instant Perfume/Candles/I...
65 =&gt; Logo
35 =&gt; Promotion
91 =&gt; Puresse
95 =&gt; Total Fresh
66 =&gt; Welcome 

{$categorie_id} empty 
{$inhoud} Array (0)

Eigenlijk simpel gezegd zou {$categorie_id} dus b.v. waarde 93 moeten hebben alleen hoe dat te doen weet ik dus niet aan de php kant van het verhaal, vandaar ook dat de eerste keer misloopt, de 2e keer als ik een keuze maar uit categorie dan geef ik de gekozen waarde mee via de post en gaat het wel goed.</description>
			<content:encoded><![CDATA[Ja zekers anders zou hij ook geen waardes meegeven<br>
<br>
ik geef je even een stuk uit het {debug} gedeelte van smarty<br>
<br>
{$SCRIPT_NAME} /home/home.php <br>
<br>
{$bedrijf_id} 27 <br>
<br>
{$categorie2} Array (13)<br>
93 =&gt; Air<br>
94 =&gt; airia<br>
67 =&gt; Assortiment<br>
72 =&gt; Dummies|Tijdelijk<br>
4 =&gt; Flush<br>
61 =&gt; Home electricals<br>
63 =&gt; Home others/Instant Car<br>
64 =&gt; Home others/Instant Perfume/Candles/I...<br>
65 =&gt; Logo<br>
35 =&gt; Promotion<br>
91 =&gt; Puresse<br>
95 =&gt; Total Fresh<br>
66 =&gt; Welcome <br>
<br>
{$categorie_id} empty <br>
{$inhoud} Array (0)<br>
<br>
Eigenlijk simpel gezegd zou {$categorie_id} dus b.v. waarde 93 moeten hebben alleen hoe dat te doen weet ik dus niet aan de php kant van het verhaal, vandaar ook dat de eerste keer misloopt, de 2e keer als ik een keuze maar uit categorie dan geef ik de gekozen waarde mee via de post en gaat het wel goed.]]></content:encoded>
			<dc:creator>Verwijderd</dc:creator>
			<guid isPermaLink="false">https://gathering.tweakers.net/forum/list_message/30102409#30102409</guid>
			<pubDate>Tue, 20 May 2008 20:23:00 GMT</pubDate>
		</item>
		<item>
			<title>Verwijderd</title>
			<link>https://gathering.tweakers.net/forum/list_message/30102378#30102378</link>
			<description>We will be using the PEAR::DB library available from PEAR. Be sure DB.php is in your include_path, or supply an absolute path to it. We will be using MySQL as our database, enter the appropriate dsn information for your database setup.Heb je dat gedaan? Dat je die DB.php in je include_path hebt?</description>
			<content:encoded><![CDATA[<blockquote><div class="message-quote-div">We will be using the PEAR::DB library available from PEAR. Be sure DB.php is in your include_path, or supply an absolute path to it. We will be using MySQL as our database, enter the appropriate dsn information for your database setup.</div></blockquote>Heb je dat gedaan? Dat je die DB.php in je include_path hebt?]]></content:encoded>
			<dc:creator>Verwijderd</dc:creator>
			<guid isPermaLink="false">https://gathering.tweakers.net/forum/list_message/30102378#30102378</guid>
			<pubDate>Tue, 20 May 2008 20:18:35 GMT</pubDate>
		</item>
		<item>
			<title>Verwijderd</title>
			<link>https://gathering.tweakers.net/forum/list_message/30102355#30102355</link>
			<description>Sorry ik zeg het verkeerd...
Smarty maakt gebruik van PEAR
vandaar DB.php

zie voorbeeld op http://www.smarty.net/sampleapp/sampleapp_p2.php

Ik Heb bovenaan ook een stuk van de template pagina gepost zodat het misschien duidelijker is.

Ik vergeet ook nog te zeggen dat ik inderdaad al aan het zoeken ben geweest op de smarty site zelf en via google, ook heb ik gezocht in de Smarty manual op www.smarty.net maar ik kon geen oplossing vinden voor dit specifieke probleem.

het grappige is dat als ik dus een selectie maak uit het categorie gedeelte dat hij dan wel de inhoud door geeft, dit komt omdat hij dan dus wel een waarde meekrijgt.

het gaat dus de eerste keer dat je op die pagina komt fout omdat hij dus vanuit de php pagina geen categorie_id meekrijgt. Dus ik zit nu helemaal vast en zie het niet zo gauw meer hoe dit op te lossen.

Waarschijnlijk is het gewoon een dom iets wat ik totaal over het hoofd zie momenteel.</description>
			<content:encoded><![CDATA[Sorry ik zeg het verkeerd...<br>
Smarty maakt gebruik van PEAR<br>
vandaar DB.php<br>
<br>
zie voorbeeld op <a href="http://www.smarty.net/sampleapp/sampleapp_p2.php" rel="external nofollow">http://www.smarty.net/sampleapp/sampleapp_p2.php</a><br>
<br>
Ik Heb bovenaan ook een stuk van de template pagina gepost zodat het misschien duidelijker is.<br>
<br>
Ik vergeet ook nog te zeggen dat ik inderdaad al aan het zoeken ben geweest op de smarty site zelf en via google, ook heb ik gezocht in de Smarty manual op <a href="http://www.smarty.net" rel="external nofollow">www.smarty.net</a> maar ik kon geen oplossing vinden voor dit specifieke probleem.<br>
<br>
het grappige is dat als ik dus een selectie maak uit het categorie gedeelte dat hij dan wel de inhoud door geeft, dit komt omdat hij dan dus wel een waarde meekrijgt.<br>
<br>
het gaat dus de eerste keer dat je op die pagina komt fout omdat hij dus vanuit de php pagina geen categorie_id meekrijgt. Dus ik zit nu helemaal vast en zie het niet zo gauw meer hoe dit op te lossen.<br>
<br>
Waarschijnlijk is het gewoon een dom iets wat ik totaal over het hoofd zie momenteel.]]></content:encoded>
			<dc:creator>Verwijderd</dc:creator>
			<guid isPermaLink="false">https://gathering.tweakers.net/forum/list_message/30102355#30102355</guid>
			<pubDate>Tue, 20 May 2008 20:14:41 GMT</pubDate>
		</item>
		<item>
			<title>Borizz</title>
			<link>https://gathering.tweakers.net/forum/list_message/30102319#30102319</link>
			<description>Verwijderd schreef op dinsdag 20 mei 2008 @ 21:59:
smarty komt met een DB.php class
die roep je aan via:
PHP:1
require (&#039;DB.php&#039;);Waar haal je die wijsheid vandaan? Smarty bevat helemaal geen database class volgens de documentatie. En ook in het download package is geen DB.php te bekennen.

Verder is het misschien handig om je probleem duidelijk te omschrijven en misschien een (relevant) gedeelte van je smarty template te posten. Heb je verder zelf al onderzocht wat de oorzaak kan zijn? Wat heb je geprobeerd? Al gezocht op internet?</description>
			<content:encoded><![CDATA[<blockquote><div class="message-quote-div"><b><a href="https://gathering.tweakers.net/forum/list_message/30102259#30102259" rel="external" class="messagelink">Verwijderd schreef op dinsdag 20 mei 2008 @ 21:59</a>:</b><br>
smarty komt met een DB.php class<br>
die roep je aan via:<br>
<div class="code">PHP:<br><table class="phphighlight"><tr><td class="phphighlightline"><pre>1
</pre></td><td class="phphighlightcode"><div><pre><span class="code_k">require</span> <span class="code_p">(</span><span class="code_s1">&#39;DB.php&#39;</span><span class="code_p">);</span></pre></div></td></tr></table></div></div></blockquote>Waar haal je die wijsheid vandaan? Smarty bevat helemaal geen database class <a href="http://www.smarty.net/manual/en/" rel="external nofollow">volgens de documentatie</a>. En ook in het download package is geen DB.php te bekennen.<br>
<br>
Verder is het misschien handig om je probleem duidelijk te omschrijven en misschien een (relevant) gedeelte van je smarty template te posten. Heb je verder zelf al onderzocht wat de oorzaak kan zijn? Wat heb je geprobeerd? Al gezocht op internet?]]></content:encoded>
			<dc:creator>Borizz</dc:creator>
			<guid isPermaLink="false">https://gathering.tweakers.net/forum/list_message/30102319#30102319</guid>
			<pubDate>Tue, 20 May 2008 20:08:31 GMT</pubDate>
		</item>
		<item>
			<title>Verwijderd</title>
			<link>https://gathering.tweakers.net/forum/list_message/30102259#30102259</link>
			<description>Smarty komt met een DB.php class, die roep je aan via:
PHP:1
require (&#039;DB.php&#039;);

Maar de query&#039;s die ik verder overal gebruik via smarty werken altijd perfect dus het zal zeker niet aan de DB class liggen.
Het enige wat ik nu dus nieuw doe in smarty is dat ik een query wil uitvoeren waarvan ik de uitvoer wil gebruiken in een nieuwe query.
Alleen weet ik dus niet hoe je dit verstandig in smarty moet doen en hoop ik dus dat iemand mij kan vertellen hoe ik dat wel zou moeten doen.

Leestekens aangepast.

Sorry ik zeg het verkeerd...
smarty maakt gebruik van PEAR
vandaar DB.php

zie voorbeeld op http://www.smarty.net/sampleapp/sampleapp_p2.php</description>
			<content:encoded><![CDATA[Smarty komt met een DB.php class, die roep je aan via:<br>
<div class="code">PHP:<br><table class="phphighlight"><tr><td class="phphighlightline"><pre>1
</pre></td><td class="phphighlightcode"><div><pre><span class="code_k">require</span> <span class="code_p">(</span><span class="code_s1">&#39;DB.php&#39;</span><span class="code_p">);</span></pre></div></td></tr></table></div><br>
<br>
Maar de query&#039;s die ik verder overal gebruik via smarty werken altijd perfect dus het zal zeker niet aan de DB class liggen.<br>
Het enige wat ik nu dus nieuw doe in smarty is dat ik een query wil uitvoeren waarvan ik de uitvoer wil gebruiken in een nieuwe query.<br>
Alleen weet ik dus niet hoe je dit verstandig in smarty moet doen en hoop ik dus dat iemand mij kan vertellen hoe ik dat wel zou moeten doen.<br>
<br>
Leestekens aangepast.<br>
<br>
Sorry ik zeg het verkeerd...<br>
smarty maakt gebruik van PEAR<br>
vandaar DB.php<br>
<br>
zie voorbeeld op <a href="http://www.smarty.net/sampleapp/sampleapp_p2.php" rel="external nofollow">http://www.smarty.net/sampleapp/sampleapp_p2.php</a>]]></content:encoded>
			<dc:creator>Verwijderd</dc:creator>
			<guid isPermaLink="false">https://gathering.tweakers.net/forum/list_message/30102259#30102259</guid>
			<pubDate>Tue, 20 May 2008 19:59:42 GMT</pubDate>
		</item>
		<item>
			<title>Raynman</title>
			<link>https://gathering.tweakers.net/forum/list_message/30102244#30102244</link>
			<description>Het gaat toch niet om Smarty, maar om de klasse DB (of komt Smarty met een DB-klasse?). Zonder meer over die klasse te weten valt er iig weinig te zeggen.

Overigens is het wel zo prettig als je gewoon hoofdletters en leestekens gebruikt.</description>
			<content:encoded><![CDATA[Het gaat toch niet om Smarty, maar om de klasse DB (of komt Smarty met een DB-klasse?). Zonder meer over die klasse te weten valt er iig weinig te zeggen.<br>
<br>
Overigens is het wel zo prettig als je gewoon hoofdletters en leestekens gebruikt.]]></content:encoded>
			<dc:creator>Raynman</dc:creator>
			<guid isPermaLink="false">https://gathering.tweakers.net/forum/list_message/30102244#30102244</guid>
			<pubDate>Tue, 20 May 2008 19:57:42 GMT</pubDate>
		</item>
		<item>
			<title>Verwijderd</title>
			<link>https://gathering.tweakers.net/forum/list_message/30102156#30102156</link>
			<description>Dat klopt, dit is ook een test nog vandaar, die if-statement kan weg inderdaad maar die wordt later nog aangepast als dit gedeelte werkt. 
Daarom zou hij het nog wel moeten doen toch?

bedrijf_id is een $_get waarde (dus die is gevuld)

Als ik smarty goed heb begrepen dan wordt de query uitgevoerd op het moment dat de template pagina wordt ingeladen, probleem daardoor is dus dat categorie_id dus leeg blijft en dus de $inhoud query niet wordt uitgevoerd. Mijn vraag is, is er een andere slimmere oplossing 

Heb ook even het uitvoer commando gepost zodat het duidelijker is hoop ik.</description>
			<content:encoded><![CDATA[Dat klopt, dit is ook een test nog vandaar, die if-statement kan weg inderdaad maar die wordt later nog aangepast als dit gedeelte werkt. <br>
Daarom zou hij het nog wel moeten doen toch?<br>
<br>
bedrijf_id is een $_get waarde (dus die is gevuld)<br>
<br>
Als ik smarty goed heb begrepen dan wordt de query uitgevoerd op het moment dat de template pagina wordt ingeladen, probleem daardoor is dus dat categorie_id dus leeg blijft en dus de $inhoud query niet wordt uitgevoerd. Mijn vraag is, is er een andere slimmere oplossing <img src="https://tweakers.net/g/s/smile.svg" width="16" height="16" alt=":)"><br>
<br>
Heb ook even het uitvoer commando gepost zodat het duidelijker is hoop ik.]]></content:encoded>
			<dc:creator>Verwijderd</dc:creator>
			<guid isPermaLink="false">https://gathering.tweakers.net/forum/list_message/30102156#30102156</guid>
			<pubDate>Tue, 20 May 2008 19:48:13 GMT</pubDate>
		</item>
		<item>
			<title>sander85</title>
			<link>https://gathering.tweakers.net/forum/list_message/30102131#30102131</link>
			<description>Een kleine opmerking: die if-statement zal altijd waar zijn. Zelfde als het controleren of 1 gelijk is aan 1.

Ik moet eerlijk bekennen dat ik smarty niet ken. Ik vraag me dan ook af waar die query&#039;s uitgevoerd gaan worden. Want zover ik zie ken je alleen waardes toe aan een query (met assign), maar worden ze (zoals de functie-naam doet vermoeden) niet uitgevoerd. (Alleen met de query achter $home2 vermoed ik dat daar wel iets uitgevoerd wordt, maar dat is enkel gissen van mijn kant.)</description>
			<content:encoded><![CDATA[Een kleine opmerking: die if-statement zal altijd waar zijn. Zelfde als het controleren of 1 gelijk is aan 1.<br>
<br>
Ik moet eerlijk bekennen dat ik smarty niet ken. Ik vraag me dan ook af waar die query&#039;s uitgevoerd gaan worden. Want zover ik zie ken je alleen waardes toe aan een query (met assign), maar worden ze (zoals de functie-naam doet vermoeden) niet uitgevoerd. (Alleen met de query achter $home2 vermoed ik dat daar wel iets uitgevoerd wordt, maar dat is enkel gissen van mijn kant.)]]></content:encoded>
			<dc:creator>sander85</dc:creator>
			<guid isPermaLink="false">https://gathering.tweakers.net/forum/list_message/30102131#30102131</guid>
			<pubDate>Tue, 20 May 2008 19:45:05 GMT</pubDate>
		</item>
		<item>
			<title>Verwijderd</title>
			<link>https://gathering.tweakers.net/forum/list_message/30102112#30102112</link>
			<description>PHP:1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
{
if ($bedrijf_id==$bedrijf_id){

// connect to database 3
$dbh2 = DB::connect(&#039;mysql://username:password@localhost/xxxl&#039;);
$dbh2-&gt;setFetchMode(DB_FETCHMODE_ASSOC);

// we want our results back as associative arrays
$home2 = $dbh2-&gt;getRow(&quot;SELECT bedrijf_id, naam FROM bedrijf WHERE bedrijf_id=&#039;$bedrijf_id&#039;&quot;);
$categorie = &quot;SELECT categorie_id, naam FROM categorie WHERE bedrijf_id=&#039;$bedrijf_id&#039; ORDER BY naam ASC&quot;;
$inhoud = &quot;SELECT inhoud_id, inhoud_naam FROM inhoud WHERE categorie_id=&#039;$categorie_id&#039; ORDER BY inhoud_naam ASC&quot;;

// assign some content
$smarty-&gt;assign(&#039;name2&#039;,$home2);
$smarty-&gt;assign(&#039;categorie2&#039;,$dbh2-&gt;getAssoc($categorie));
$smarty-&gt;assign(&#039;inhoud2&#039;,$dbh2-&gt;getAssoc($inhoud));
}
// display it (uitvoering)
$smarty-&gt;display(&#039;home.tpl&#039;);

home.tpl
PHP:1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
&lt;form method=&quot;POST&quot; enctype=&quot;multipart/form-data&quot; name=&quot;myform&quot; action=&quot;home.php?bedrijf_id={$name2.bedrijf_id}&amp;categorie_id={$categorie_id}&quot;&gt;
                &lt;table&gt;
                    &lt;tr&gt;
                        &lt;td&gt;&lt;img src=&quot;/display/view1.php?bedrijf_id={$name2.bedrijf_id}&quot; border=&quot;0&quot; name=&quot;{$name2.naam}&quot; alt=&quot;{$name2.naam}&quot;&gt;&lt;/td&gt;
                        &lt;td&gt;categorie:&lt;br /&gt;
                            &lt;select name=&quot;categorie&quot; onChange=&quot;document.location.href = &#039;home.php?bedrijf_id={$name2.bedrijf_id}&amp;categorie_id=&#039; + myform.categorie.value;&quot;&gt;
                                {html_options options=$categorie1|truncate:20}
                                {html_options options=$categorie2|truncate:20}
                            &lt;/select&gt;&lt;/td&gt;
                        &lt;td&gt;inhoud:&lt;br /&gt;
                            &lt;select name=&quot;inhoud&quot; onchange=&quot;document.location.href = &#039;home.php?bedrijf_id={$name2.bedrijf_id}&amp;categorie_id={$categorie_id}&amp;inhoud_id=&#039; + myform.inhoud.value;&quot;&gt;
                                {html_options options=$inhoud|truncate:20}
                                {html_options options=$inhoud2|truncate:20}
                            &lt;/select&gt;&lt;/td&gt;
                    &lt;/tr&gt;
                    &lt;tr&gt;
                        &lt;td&gt;&lt;/td&gt;
                        &lt;td&gt;&lt;/td&gt;
                        &lt;td&gt;&lt;/td&gt;
                    &lt;/tr&gt;
                 &lt;/table&gt;
              &lt;/form&gt;

Probleem:
$bedrijf_id bekend is, dus de query loopt goed tot en met query $inhoud.
$categorie_id leeg is, maar ik graag zou zien dat hij uit de query$categorie $categorie_id gebruikt.

Hoe dit verstandig te doen in smarty?
Iiemand suggesties?

Verdere omschrijving:
Waarom ik meerdere query&#039;s heb is omdat de resultaten in verschillende select boxen worden gebruikt, dus inhoudarray verandert als de categoriearray verandert.

Alvast bedankt voor reacties en ik weet dat ik een prutser ben daarom mijn vraag aan jullie  

Leestekens aangepast.</description>
			<content:encoded><![CDATA[<div class="code">PHP:<br><table class="phphighlight"><tr><td class="phphighlightline"><pre>1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
</pre></td><td class="phphighlightcode"><div><pre><span class="code_p">{</span>
<span class="code_k">if</span> <span class="code_p">(</span><span class="code_nv">$bedrijf_id</span><span class="code_o">==</span><span class="code_nv">$bedrijf_id</span><span class="code_p">){</span>

<span class="code_c1">// connect to database 3</span>
<span class="code_nv">$dbh2</span> <span class="code_o">=</span> <span class="code_nx">DB</span><span class="code_o">::</span><span class="code_na">connect</span><span class="code_p">(</span><span class="code_s1">&#39;mysql://username:password@localhost/xxxl&#39;</span><span class="code_p">);</span>
<span class="code_nv">$dbh2</span><span class="code_o">-&gt;</span><span class="code_na">setFetchMode</span><span class="code_p">(</span><span class="code_nx">DB_FETCHMODE_ASSOC</span><span class="code_p">);</span>

<span class="code_c1">// we want our results back as associative arrays</span>
<span class="code_nv">$home2</span> <span class="code_o">=</span> <span class="code_nv">$dbh2</span><span class="code_o">-&gt;</span><span class="code_na">getRow</span><span class="code_p">(</span><span class="code_s2">&quot;SELECT bedrijf_id, naam FROM bedrijf WHERE bedrijf_id=&#39;</span><span class="code_si">$bedrijf_id</span><span class="code_s2">&#39;&quot;</span><span class="code_p">);</span>
<span class="code_nv">$categorie</span> <span class="code_o">=</span> <span class="code_s2">&quot;SELECT categorie_id, naam FROM categorie WHERE bedrijf_id=&#39;</span><span class="code_si">$bedrijf_id</span><span class="code_s2">&#39; ORDER BY naam ASC&quot;</span><span class="code_p">;</span>
<span class="code_nv">$inhoud</span> <span class="code_o">=</span> <span class="code_s2">&quot;SELECT inhoud_id, inhoud_naam FROM inhoud WHERE categorie_id=&#39;</span><span class="code_si">$categorie_id</span><span class="code_s2">&#39; ORDER BY inhoud_naam ASC&quot;</span><span class="code_p">;</span>

<span class="code_c1">// assign some content</span>
<span class="code_nv">$smarty</span><span class="code_o">-&gt;</span><span class="code_na">assign</span><span class="code_p">(</span><span class="code_s1">&#39;name2&#39;</span><span class="code_p">,</span><span class="code_nv">$home2</span><span class="code_p">);</span>
<span class="code_nv">$smarty</span><span class="code_o">-&gt;</span><span class="code_na">assign</span><span class="code_p">(</span><span class="code_s1">&#39;categorie2&#39;</span><span class="code_p">,</span><span class="code_nv">$dbh2</span><span class="code_o">-&gt;</span><span class="code_na">getAssoc</span><span class="code_p">(</span><span class="code_nv">$categorie</span><span class="code_p">));</span>
<span class="code_nv">$smarty</span><span class="code_o">-&gt;</span><span class="code_na">assign</span><span class="code_p">(</span><span class="code_s1">&#39;inhoud2&#39;</span><span class="code_p">,</span><span class="code_nv">$dbh2</span><span class="code_o">-&gt;</span><span class="code_na">getAssoc</span><span class="code_p">(</span><span class="code_nv">$inhoud</span><span class="code_p">));</span>
<span class="code_p">}</span>
<span class="code_c1">// display it (uitvoering)</span>
<span class="code_nv">$smarty</span><span class="code_o">-&gt;</span><span class="code_na">display</span><span class="code_p">(</span><span class="code_s1">&#39;home.tpl&#39;</span><span class="code_p">);</span></pre></div></td></tr></table></div><br>
<br>
home.tpl<br>
<div class="code">PHP:<br><table class="phphighlight"><tr><td class="phphighlightline"><pre>1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
</pre></td><td class="phphighlightcode"><div><pre><span class="code_o">&lt;</span><span class="code_nx">form</span> <span class="code_nx">method</span><span class="code_o">=</span><span class="code_s2">&quot;POST&quot;</span> <span class="code_nx">enctype</span><span class="code_o">=</span><span class="code_s2">&quot;multipart/form-data&quot;</span> <span class="code_nx">name</span><span class="code_o">=</span><span class="code_s2">&quot;myform&quot;</span> <span class="code_nx">action</span><span class="code_o">=</span><span class="code_s2">&quot;home.php?bedrijf_id=</span><span class="code_si">{</span><span class="code_nv">$name2</span><span class="code_o">.</span><span class="code_nx">bedrijf_id</span><span class="code_si">}</span><span class="code_s2">&amp;categorie_id=</span><span class="code_si">{</span><span class="code_nv">$categorie_id</span><span class="code_si">}</span><span class="code_s2">&quot;</span><span class="code_o">&gt;</span>
                <span class="code_o">&lt;</span><span class="code_nx">table</span><span class="code_o">&gt;</span>
                    <span class="code_o">&lt;</span><span class="code_nx">tr</span><span class="code_o">&gt;</span>
                        <span class="code_o">&lt;</span><span class="code_nx">td</span><span class="code_o">&gt;&lt;</span><span class="code_nx">img</span> <span class="code_nx">src</span><span class="code_o">=</span><span class="code_s2">&quot;/display/view1.php?bedrijf_id=</span><span class="code_si">{</span><span class="code_nv">$name2</span><span class="code_o">.</span><span class="code_nx">bedrijf_id</span><span class="code_si">}</span><span class="code_s2">&quot;</span> <span class="code_nx">border</span><span class="code_o">=</span><span class="code_s2">&quot;0&quot;</span> <span class="code_nx">name</span><span class="code_o">=</span><span class="code_s2">&quot;</span><span class="code_si">{</span><span class="code_nv">$name2</span><span class="code_o">.</span><span class="code_nx">naam</span><span class="code_si">}</span><span class="code_s2">&quot;</span> <span class="code_nx">alt</span><span class="code_o">=</span><span class="code_s2">&quot;</span><span class="code_si">{</span><span class="code_nv">$name2</span><span class="code_o">.</span><span class="code_nx">naam</span><span class="code_si">}</span><span class="code_s2">&quot;</span><span class="code_o">&gt;&lt;/</span><span class="code_nx">td</span><span class="code_o">&gt;</span>
                        <span class="code_o">&lt;</span><span class="code_nx">td</span><span class="code_o">&gt;</span><span class="code_nx">categorie</span><span class="code_o">:&lt;</span><span class="code_nx">br</span> <span class="code_o">/&gt;</span>
                            <span class="code_o">&lt;</span><span class="code_nx">select</span> <span class="code_nx">name</span><span class="code_o">=</span><span class="code_s2">&quot;categorie&quot;</span> <span class="code_nx">onChange</span><span class="code_o">=</span><span class="code_s2">&quot;document.location.href = &#39;home.php?bedrijf_id=</span><span class="code_si">{</span><span class="code_nv">$name2</span><span class="code_o">.</span><span class="code_nx">bedrijf_id</span><span class="code_si">}</span><span class="code_s2">&amp;categorie_id=&#39; + myform.categorie.value;&quot;</span><span class="code_o">&gt;</span>
                                <span class="code_p">{</span><span class="code_nx">html_options</span> <span class="code_nx">options</span><span class="code_o">=</span><span class="code_nv">$categorie1</span><span class="code_o">|</span><span class="code_nx">truncate</span><span class="code_o">:</span><span class="code_mi">20</span><span class="code_p">}</span>
                                <span class="code_p">{</span><span class="code_nx">html_options</span> <span class="code_nx">options</span><span class="code_o">=</span><span class="code_nv">$categorie2</span><span class="code_o">|</span><span class="code_nx">truncate</span><span class="code_o">:</span><span class="code_mi">20</span><span class="code_p">}</span>
                            <span class="code_o">&lt;/</span><span class="code_nx">select</span><span class="code_o">&gt;&lt;/</span><span class="code_nx">td</span><span class="code_o">&gt;</span>
                        <span class="code_o">&lt;</span><span class="code_nx">td</span><span class="code_o">&gt;</span><span class="code_nx">inhoud</span><span class="code_o">:&lt;</span><span class="code_nx">br</span> <span class="code_o">/&gt;</span>
                            <span class="code_o">&lt;</span><span class="code_nx">select</span> <span class="code_nx">name</span><span class="code_o">=</span><span class="code_s2">&quot;inhoud&quot;</span> <span class="code_nx">onchange</span><span class="code_o">=</span><span class="code_s2">&quot;document.location.href = &#39;home.php?bedrijf_id=</span><span class="code_si">{</span><span class="code_nv">$name2</span><span class="code_o">.</span><span class="code_nx">bedrijf_id</span><span class="code_si">}</span><span class="code_s2">&amp;categorie_id=</span><span class="code_si">{</span><span class="code_nv">$categorie_id</span><span class="code_si">}</span><span class="code_s2">&amp;inhoud_id=&#39; + myform.inhoud.value;&quot;</span><span class="code_o">&gt;</span>
                                <span class="code_p">{</span><span class="code_nx">html_options</span> <span class="code_nx">options</span><span class="code_o">=</span><span class="code_nv">$inhoud</span><span class="code_o">|</span><span class="code_nx">truncate</span><span class="code_o">:</span><span class="code_mi">20</span><span class="code_p">}</span>
                                <span class="code_p">{</span><span class="code_nx">html_options</span> <span class="code_nx">options</span><span class="code_o">=</span><span class="code_nv">$inhoud2</span><span class="code_o">|</span><span class="code_nx">truncate</span><span class="code_o">:</span><span class="code_mi">20</span><span class="code_p">}</span>
                            <span class="code_o">&lt;/</span><span class="code_nx">select</span><span class="code_o">&gt;&lt;/</span><span class="code_nx">td</span><span class="code_o">&gt;</span>
                    <span class="code_o">&lt;/</span><span class="code_nx">tr</span><span class="code_o">&gt;</span>
                    <span class="code_o">&lt;</span><span class="code_nx">tr</span><span class="code_o">&gt;</span>
                        <span class="code_o">&lt;</span><span class="code_nx">td</span><span class="code_o">&gt;&lt;/</span><span class="code_nx">td</span><span class="code_o">&gt;</span>
                        <span class="code_o">&lt;</span><span class="code_nx">td</span><span class="code_o">&gt;&lt;/</span><span class="code_nx">td</span><span class="code_o">&gt;</span>
                        <span class="code_o">&lt;</span><span class="code_nx">td</span><span class="code_o">&gt;&lt;/</span><span class="code_nx">td</span><span class="code_o">&gt;</span>
                    <span class="code_o">&lt;/</span><span class="code_nx">tr</span><span class="code_o">&gt;</span>
                 <span class="code_o">&lt;/</span><span class="code_nx">table</span><span class="code_o">&gt;</span>
              <span class="code_o">&lt;/</span><span class="code_nx">form</span><span class="code_o">&gt;</span></pre></div></td></tr></table></div><br>
<br>
Probleem:<br>
$bedrijf_id bekend is, dus de query loopt goed tot en met query $inhoud.<br>
$categorie_id leeg is, maar ik graag zou zien dat hij uit de query$categorie $categorie_id gebruikt.<br>
<br>
Hoe dit verstandig te doen in smarty?<br>
Iiemand suggesties?<br>
<br>
Verdere omschrijving:<br>
Waarom ik meerdere query&#039;s heb is omdat de resultaten in verschillende select boxen worden gebruikt, dus inhoudarray verandert als de categoriearray verandert.<br>
<br>
Alvast bedankt voor reacties en ik weet dat ik een prutser ben daarom mijn vraag aan jullie  <img src="https://tweakers.net/g/s/clown.svg" width="16" height="16" alt=":+"><br>
<br>
Leestekens aangepast.]]></content:encoded>
			<dc:creator>Verwijderd</dc:creator>
			<guid isPermaLink="false">https://gathering.tweakers.net/forum/list_message/30102112#30102112</guid>
			<pubDate>Tue, 20 May 2008 19:42:37 GMT</pubDate>
		</item>
	</channel>
</rss>