qsql_sqlite2.h
上传用户:detong
上传日期:2022-06-22
资源大小:20675k
文件大小:4k
源码类别:

系统编程

开发平台:

Unix_Linux

  1. /****************************************************************************
  2. **
  3. ** Copyright (C) 2008 Nokia Corporation and/or its subsidiary(-ies).
  4. ** Contact: Qt Software Information (qt-info@nokia.com)
  5. **
  6. ** This file is part of the QtSql module of the Qt Toolkit.
  7. **
  8. ** Commercial Usage
  9. ** Licensees holding valid Qt Commercial licenses may use this file in
  10. ** accordance with the Qt Commercial License Agreement provided with the
  11. ** Software or, alternatively, in accordance with the terms contained in
  12. ** a written agreement between you and Nokia.
  13. **
  14. **
  15. ** GNU General Public License Usage
  16. ** Alternatively, this file may be used under the terms of the GNU
  17. ** General Public License versions 2.0 or 3.0 as published by the Free
  18. ** Software Foundation and appearing in the file LICENSE.GPL included in
  19. ** the packaging of this file.  Please review the following information
  20. ** to ensure GNU General Public Licensing requirements will be met:
  21. ** http://www.fsf.org/licensing/licenses/info/GPLv2.html and
  22. ** http://www.gnu.org/copyleft/gpl.html.  In addition, as a special
  23. ** exception, Nokia gives you certain additional rights. These rights
  24. ** are described in the Nokia Qt GPL Exception version 1.3, included in
  25. ** the file GPL_EXCEPTION.txt in this package.
  26. **
  27. ** Qt for Windows(R) Licensees
  28. ** As a special exception, Nokia, as the sole copyright holder for Qt
  29. ** Designer, grants users of the Qt/Eclipse Integration plug-in the
  30. ** right for the Qt/Eclipse Integration to link to functionality
  31. ** provided by Qt Designer and its related libraries.
  32. **
  33. ** If you are unsure which license is appropriate for your use, please
  34. ** contact the sales department at qt-sales@nokia.com.
  35. **
  36. ****************************************************************************/
  37. #ifndef QSQL_SQLITE2_H
  38. #define QSQL_SQLITE2_H
  39. #include <QtSql/qsqldriver.h>
  40. #include <QtSql/qsqlresult.h>
  41. #include <QtSql/qsqlrecord.h>
  42. #include <QtSql/qsqlindex.h>
  43. #include <QtSql/private/qsqlcachedresult_p.h>
  44. #if defined (Q_OS_WIN32)
  45. # include <QtCore/qt_windows.h>
  46. #endif
  47. struct sqlite;
  48. QT_BEGIN_HEADER
  49. QT_BEGIN_NAMESPACE
  50. class QSQLite2DriverPrivate;
  51. class QSQLite2ResultPrivate;
  52. class QSQLite2Driver;
  53. class QSQLite2Result : public QSqlCachedResult
  54. {
  55.     friend class QSQLite2Driver;
  56.     friend class QSQLite2ResultPrivate;
  57. public:
  58.     explicit QSQLite2Result(const QSQLite2Driver* db);
  59.     ~QSQLite2Result();
  60.     QVariant handle() const;
  61. protected:
  62.     bool gotoNext(QSqlCachedResult::ValueCache& row, int idx);
  63.     bool reset (const QString& query);
  64.     int size();
  65.     int numRowsAffected();
  66.     QSqlRecord record() const;
  67.     void virtual_hook(int id, void *data);
  68. private:
  69.     QSQLite2ResultPrivate* d;
  70. };
  71. class QSQLite2Driver : public QSqlDriver
  72. {
  73.     Q_OBJECT
  74.     friend class QSQLite2Result;
  75. public:
  76.     explicit QSQLite2Driver(QObject *parent = 0);
  77.     explicit QSQLite2Driver(sqlite *connection, QObject *parent = 0);
  78.     ~QSQLite2Driver();
  79.     bool hasFeature(DriverFeature f) const;
  80.     bool open(const QString & db,
  81.                    const QString & user,
  82.                    const QString & password,
  83.                    const QString & host,
  84.                    int port,
  85.                    const QString & connOpts);
  86.     bool open(const QString & db,
  87.             const QString & user,
  88.             const QString & password,
  89.             const QString & host,
  90.             int port) { return open (db, user, password, host, port, QString()); }
  91.     void close();
  92.     QSqlResult *createResult() const;
  93.     bool beginTransaction();
  94.     bool commitTransaction();
  95.     bool rollbackTransaction();
  96.     QStringList tables(QSql::TableType) const;
  97.     QSqlRecord record(const QString& tablename) const;
  98.     QSqlIndex primaryIndex(const QString &table) const;
  99.     QVariant handle() const;
  100. private:
  101.     QSQLite2DriverPrivate* d;
  102. };
  103. QT_END_NAMESPACE
  104. QT_END_HEADER
  105. #endif // QSQL_SQLITE2_H