qsqlquery.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 QSQLQUERY_H
  38. #define QSQLQUERY_H
  39. #include <QtSql/qsql.h>
  40. #include <QtSql/qsqldatabase.h>
  41. #include <QtCore/qstring.h>
  42. QT_BEGIN_HEADER
  43. QT_BEGIN_NAMESPACE
  44. QT_MODULE(Sql)
  45. class QVariant;
  46. class QSqlDriver;
  47. class QSqlError;
  48. class QSqlResult;
  49. class QSqlRecord;
  50. template <class Key, class T> class QMap;
  51. class QSqlQueryPrivate;
  52. class Q_SQL_EXPORT QSqlQuery
  53. {
  54. public:
  55.     QSqlQuery(QSqlResult *r);
  56.     QSqlQuery(const QString& query = QString(), QSqlDatabase db = QSqlDatabase());
  57.     explicit QSqlQuery(QSqlDatabase db);
  58.     QSqlQuery(const QSqlQuery& other);
  59.     QSqlQuery& operator=(const QSqlQuery& other);
  60.     ~QSqlQuery();
  61.     bool isValid() const;
  62.     bool isActive() const;
  63.     bool isNull(int field) const;
  64.     int at() const;
  65.     QString lastQuery() const;
  66.     int numRowsAffected() const;
  67.     QSqlError lastError() const;
  68.     bool isSelect() const;
  69.     int size() const;
  70.     const QSqlDriver* driver() const;
  71.     const QSqlResult* result() const;
  72.     bool isForwardOnly() const;
  73.     QSqlRecord record() const;
  74.     void setForwardOnly(bool forward);
  75.     bool exec(const QString& query);
  76.     QVariant value(int i) const;
  77.     void setNumericalPrecisionPolicy(QSql::NumericalPrecisionPolicy precisionPolicy);
  78.     QSql::NumericalPrecisionPolicy numericalPrecisionPolicy() const;
  79.     bool seek(int i, bool relative = false);
  80.     bool next();
  81.     bool previous();
  82. #ifdef QT3_SUPPORT
  83.     inline QT3_SUPPORT bool prev() { return previous(); }
  84. #endif
  85.     bool first();
  86.     bool last();
  87.     void clear();
  88.     // prepared query support
  89.     bool exec();
  90.     enum BatchExecutionMode { ValuesAsRows, ValuesAsColumns };
  91.     bool execBatch(BatchExecutionMode mode = ValuesAsRows);
  92.     bool prepare(const QString& query);
  93.     void bindValue(const QString& placeholder, const QVariant& val,
  94.                    QSql::ParamType type = QSql::In);
  95.     void bindValue(int pos, const QVariant& val, QSql::ParamType type = QSql::In);
  96.     void addBindValue(const QVariant& val, QSql::ParamType type = QSql::In);
  97.     QVariant boundValue(const QString& placeholder) const;
  98.     QVariant boundValue(int pos) const;
  99.     QMap<QString, QVariant> boundValues() const;
  100.     QString executedQuery() const;
  101.     QVariant lastInsertId() const;
  102.     void finish();
  103.     bool nextResult();
  104. private:
  105.     QSqlQueryPrivate* d;
  106. };
  107. QT_END_NAMESPACE
  108. QT_END_HEADER
  109. #endif // QSQLQUERY_H