1
/****************************************************************************
3
** Copyright (C) 1992-2005 Trolltech AS. All rights reserved.
5
** This file is part of the sql module of the Qt Toolkit.
7
** This file may be distributed under the terms of the Q Public License
8
** as defined by Trolltech AS of Norway and appearing in the file
9
** LICENSE.QPL included in the packaging of this file.
11
** This file may be distributed and/or modified under the terms of the
12
** GNU General Public License version 2 as published by the Free Software
13
** Foundation and appearing in the file LICENSE.GPL included in the
14
** packaging of this file.
16
** See http://www.trolltech.com/pricing.html or email sales@trolltech.com for
17
** information about Qt Commercial License Agreements.
18
** See http://www.trolltech.com/qpl/ for QPL licensing information.
19
** See http://www.trolltech.com/gpl/ for GPL licensing information.
21
** Contact info@trolltech.com if any conditions of this licensing are
24
** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
25
** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
27
****************************************************************************/
32
#include <QtSql/qsqldriver.h>
33
#include <QtSql/qsqlresult.h>
34
#include <QtSql/qsqlrecord.h>
35
#include <QtSql/qsqlindex.h>
36
#include <QtSql/private/qsqlcachedresult_p.h>
38
#if defined (Q_OS_WIN32)
39
# include <QtCore/qt_windows.h>
42
class QSQLite2DriverPrivate;
43
class QSQLite2ResultPrivate;
47
class QSQLite2Result : public QSqlCachedResult
49
friend class QSQLite2Driver;
50
friend class QSQLite2ResultPrivate;
52
explicit QSQLite2Result(const QSQLite2Driver* db);
54
QVariant handle() const;
57
bool gotoNext(QSqlCachedResult::ValueCache& row, int idx);
58
bool reset (const QString& query);
60
int numRowsAffected();
61
QSqlRecord record() const;
64
QSQLite2ResultPrivate* d;
67
class QSQLite2Driver : public QSqlDriver
69
friend class QSQLite2Result;
71
explicit QSQLite2Driver(QObject *parent = 0);
72
explicit QSQLite2Driver(sqlite *connection, QObject *parent = 0);
74
bool hasFeature(DriverFeature f) const;
75
bool open(const QString & db,
77
const QString & password,
80
const QString & connOpts);
81
bool open(const QString & db,
83
const QString & password,
85
int port) { return open (db, user, password, host, port, QString()); }
87
QSqlResult *createResult() const;
88
bool beginTransaction();
89
bool commitTransaction();
90
bool rollbackTransaction();
91
QStringList tables(QSql::TableType) const;
93
QSqlRecord record(const QString& tablename) const;
94
QSqlIndex primaryIndex(const QString &table) const;
95
QVariant handle() const;
98
QSQLite2DriverPrivate* d;
101
#endif // QSQL_SQLITE_H