4
* Copyright (C) 2009 Tim Marston <edam@waxworlds.org>
6
* This file is part of sqlitepp (hereafter referred to as "this program").
7
* See http://www.waxworlds.org/edam/software/sqlitepp for more information.
9
* This program is free software: you can redistribute it and/or modify
10
* it under the terms of the GNU Lesser General Public License as published
11
* by the Free Software Foundation, either version 3 of the License, or
12
* (at your option) any later version.
14
* This program is distributed in the hope that it will be useful,
15
* but WITHOUT ANY WARRANTY; without even the implied warranty of
16
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17
* GNU Lesser General Public License for more details.
4
* Copyright (C) 2009 Tim Marston <tim@ed.am>
6
* This file is part of sqlite3cc (hereafter referred to as "this program").
7
* See http://ed.am/dev/sqlite3cc for more information.
9
* This program is free software: you can redistribute it and/or modify it under
10
* the terms of the GNU Lesser General Public License as published by the Free
11
* Software Foundation, either version 3 of the License, or (at your option) any
14
* This program is distributed in the hope that it will be useful, but WITHOUT
15
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
16
* FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
19
19
* You should have received a copy of the GNU Lesser General Public License
20
20
* along with this program. If not, see <http://www.gnu.org/licenses/>.
23
#include <sqlitepp/statement.hpp>
24
#include <sqlitepp/exception.hpp>
25
#include <sqlitepp/database.hpp>
23
#include <sqlite3cc/basic_statement.h>
24
#include <sqlite3cc/exception.h>
25
#include <sqlite3cc/connection.h>
26
#include <sqlite3cc/manipulator.h>
26
27
#include <string.h>
30
const sqlite::_null_t sqlite::null = { };
32
const sqlite::_exec_t sqlite::exec = { };
35
sqlite::_set_index_t sqlite::set_index(
38
_set_index_t t = { index };
43
sqlite::statement::statement(
45
const std::string &sql )
47
_database( database ),
51
int error_code = prepare( sql );
52
if( error_code != SQLITE_OK ) throw sqlite_error( error_code );
56
sqlite::statement::~statement() throw( )
62
int sqlite::statement::prepare(
63
const std::string &sql )
66
return sqlite3_prepare_v2( _database._handle, sql.c_str(),
30
sqlite::detail::basic_statement::basic_statement(
31
connection &connection,
32
const std::string &sql )
34
_connection( connection ),
38
int code = prepare( sql );
39
if( code != SQLITE_OK ) throw sqlite_error( connection, code );
43
sqlite::detail::basic_statement::basic_statement(
44
connection &connection )
46
_connection( connection ),
53
sqlite::detail::basic_statement::~basic_statement()
59
int sqlite::detail::basic_statement::prepare(
60
const std::string &sql )
63
return sqlite3_prepare_v2( _connection._handle, sql.c_str(),
67
64
sql.length() + 1, &_handle, NULL );
71
int sqlite::statement::step()
73
return sqlite3_step( _handle );
77
int sqlite::statement::reset()
68
int sqlite::detail::basic_statement::reset()
79
70
return sqlite3_reset( _handle );
83
int sqlite::statement::clear_bindings()
74
int sqlite::detail::basic_statement::clear_bindings()
86
77
return sqlite3_clear_bindings( _handle );
90
int sqlite::statement::bind_static(
81
int sqlite::detail::basic_statement::bind_static(
91
82
unsigned int index,
93
84
unsigned int value_length )
116
int sqlite::statement::bind_null(
107
int sqlite::detail::basic_statement::bind_null(
117
108
unsigned int index )
119
110
return sqlite3_bind_null( _handle, index );
123
int sqlite::statement::bind_static(
114
int sqlite::detail::basic_statement::bind_static(
124
115
const std::string &name,
125
116
const char *value,
126
117
unsigned int value_length )
128
unsigned int index = sqlite3_bind_parameter_index( _handle, name.c_str() );
129
return bind_static( index, value, value_length );
119
return bind_static( bind_parameter_index( name ), value, value_length );
133
int sqlite::statement::bind_static(
123
int sqlite::detail::basic_statement::bind_static(
134
124
const std::string &name,
135
125
const char *value )
149
int sqlite::statement::bind_null(
139
int sqlite::detail::basic_statement::bind_null(
150
140
const std::string &name )
152
unsigned int index = sqlite3_bind_parameter_index( _handle, name.c_str() );
153
return bind_null( index );
142
return bind_null( bind_parameter_index( name ) );
157
int sqlite::statement::finalize()
146
int sqlite::detail::basic_statement::finalize()
159
int error_code = SQLITE_OK;
148
int code = SQLITE_OK;
162
error_code = sqlite3_finalize( _handle );
151
code = sqlite3_finalize( _handle );
159
int sqlite::detail::basic_statement::bind_parameter_index(
160
const std::string &name )
162
unsigned int index = sqlite3_bind_parameter_index( _handle, name.c_str() );
163
if( !index ) throw std::range_error( "named parameter not found" );
168
int sqlite::detail::basic_statement::step()
170
return sqlite3_step( _handle );
171
sqlite::statement& sqlite::statement::operator << < sqlite::_null_t >(
176
sqlite::detail::basic_statement &sqlite::detail::basic_statement::operator <<
177
< sqlite::detail::null_t >(
178
const sqlite::detail::null_t & )
174
int error_code = bind_null( _bind_index );
175
if( error_code != SQLITE_OK ) throw sqlite_error( error_code );
180
int code = bind_null( _bind_index );
181
if( code != SQLITE_OK ) throw sqlite_error( _connection, code );
181
sqlite::statement& sqlite::statement::operator << < sqlite::_exec_t >(
184
int error_code = step();
185
if( error_code != SQLITE_DONE )
186
if( error_code == SQLITE_ROW )
187
throw sqlite_error( "statement returned results" );
189
throw sqlite_error( error_code );
194
sqlite::statement& sqlite::statement::operator << < sqlite::_set_index_t >(
195
sqlite::_set_index_t t )
188
sqlite::detail::basic_statement &sqlite::detail::basic_statement::operator <<
189
< sqlite::detail::set_index_t >(
190
const sqlite::detail::set_index_t &t )
197
192
_bind_index = t._index;