-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathconnection.hpp
86 lines (67 loc) · 2.66 KB
/
connection.hpp
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
/*
* sqlite3xx - sqlite3 C++ layer, following the ideas of libpqxx
* Copyright (C) 2009 Andreas Baumann
*
* This copyrighted material is made available to anyone wishing to use,
* modify, copy, or redistribute it subject to the terms and conditions of
* the GNU Lesser General Public License, as published by the Free Software
* Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
* License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this distribution; if not, write to:
* Free Software Foundation, Inc.
* 51 Franklin Street, Fifth Floor
* Boston, MA 02110-1301 USA
*
*/
#ifndef SQLITE3XX_CONNECTION_H
#define SQLITE3XX_CONNECTION_H
#include "prepared_statement.hpp"
#include "result.hpp"
#include <map>
#include <iostream>
#include "port/stdint.h" /* for uintmax_t */
#include "port/dllexport.h"
namespace sqlite3xx {
class prepared_stmt;
class result;
class SQLITEXX_LIBEXPORT connection {
private:
typedef map<string, prepared_stmt *> PSMap;
unsigned int _internal_tno;
string _filename;
sqlite3 *db;
PSMap prepared_stmts;
bool _trace;
SQLITEXX_PRIVATE prepared_stmt* find_prepared( const string& name );
public:
connection( );
connection( string filename );
connection( const connection& c );
~connection( );
void trace( bool __trace );
bool trace( ) { return _trace; }
result exec( string sql );
result prepared_exec( const string& name );
prepare::declaration prepare( const string& name, string sql );
void prepare_param_declare( const string& stmt, const string& sqltype, prepare::param_treatment& treatment );
void prepared_reset( const string& name );
void prepare_setparam( const string& name, const int pos, const int value );
void prepare_setparam( const string& name, const int pos, const unsigned int value );
void prepare_setparam( const string& name, const int pos, const char* value );
void prepare_setparam(const string& name, const int pos, const unsigned char* value, int bycount);
void prepare_setparam( const string& name, const int pos, const double value );
void prepare_setparam( const string& name, const int pos, const long value );
void prepare_setparam( const string& name, const int pos, const uintmax_t value );
void unprepare( string name );
SQLITEXX_LIBEXPORT friend ostream& operator<<( ostream& o, const connection& c );
const char *dbname( ) { return _filename.c_str( ); };
};
}
#endif /* SQLITE3XX_CONNECTION_H */