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/qsqlresult.h>
33
#include <QtSql/qsqldriver.h>
36
#define Q_EXPORT_SQLDRIVER_PSQL
38
#define Q_EXPORT_SQLDRIVER_PSQL Q_SQL_EXPORT
41
typedef struct pg_conn PGconn;
42
typedef struct pg_result PGresult;
44
class QPSQLResultPrivate;
45
class QPSQLDriverPrivate;
49
class QPSQLResult : public QSqlResult
51
friend class QPSQLResultPrivate;
53
QPSQLResult(const QPSQLDriver* db, const QPSQLDriverPrivate* p);
56
QVariant handle() const;
64
bool isNull(int field);
65
bool reset (const QString& query);
67
int numRowsAffected();
68
QSqlRecord record() const;
69
QVariant lastInsertId() const;
72
QPSQLResultPrivate *d;
75
class Q_EXPORT_SQLDRIVER_PSQL QPSQLDriver : public QSqlDriver
86
explicit QPSQLDriver(QObject *parent=0);
87
explicit QPSQLDriver(PGconn *conn, QObject *parent=0);
89
bool hasFeature(DriverFeature f) const;
90
bool open(const QString & db,
92
const QString & password,
95
const QString& connOpts);
98
QSqlResult *createResult() const;
99
QStringList tables(QSql::TableType) const;
100
QSqlIndex primaryIndex(const QString& tablename) const;
101
QSqlRecord record(const QString& tablename) const;
103
Protocol protocol() const;
104
QVariant handle() const;
106
QString escapeIdentifier(const QString &identifier, IdentifierType type) const;
107
QString formatValue(const QSqlField &field,
108
bool trimStrings) const;
111
bool beginTransaction();
112
bool commitTransaction();
113
bool rollbackTransaction();
116
QPSQLDriverPrivate *d;
119
#endif // QSQL_PSQL_H