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

系统编程

开发平台:

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 QSQLTABLEMODEL_H
  38. #define QSQLTABLEMODEL_H
  39. #include <QtSql/qsqldatabase.h>
  40. #include <QtSql/qsqlquerymodel.h>
  41. QT_BEGIN_HEADER
  42. QT_BEGIN_NAMESPACE
  43. QT_MODULE(Sql)
  44. class QSqlTableModelPrivate;
  45. class QSqlRecord;
  46. class QSqlField;
  47. class QSqlIndex;
  48. class Q_SQL_EXPORT QSqlTableModel: public QSqlQueryModel
  49. {
  50.     Q_OBJECT
  51.     Q_DECLARE_PRIVATE(QSqlTableModel)
  52. public:
  53.     enum EditStrategy {OnFieldChange, OnRowChange, OnManualSubmit};
  54.     explicit QSqlTableModel(QObject *parent = 0, QSqlDatabase db = QSqlDatabase());
  55.     virtual ~QSqlTableModel();
  56.     virtual bool select();
  57.     virtual void setTable(const QString &tableName);
  58.     QString tableName() const;
  59.     Qt::ItemFlags flags(const QModelIndex &index) const;
  60.     QVariant data(const QModelIndex &idx, int role = Qt::DisplayRole) const;
  61.     bool setData(const QModelIndex &index, const QVariant &value, int role = Qt::EditRole);
  62.     QVariant headerData(int section, Qt::Orientation orientation, int role = Qt::DisplayRole) const;
  63.     bool isDirty(const QModelIndex &index) const;
  64.     void clear();
  65.     virtual void setEditStrategy(EditStrategy strategy);
  66.     EditStrategy editStrategy() const;
  67.     QSqlIndex primaryKey() const;
  68.     QSqlDatabase database() const;
  69.     int fieldIndex(const QString &fieldName) const;
  70.     void sort(int column, Qt::SortOrder order);
  71.     virtual void setSort(int column, Qt::SortOrder order);
  72.     QString filter() const;
  73.     virtual void setFilter(const QString &filter);
  74.     int rowCount(const QModelIndex &parent = QModelIndex()) const;
  75.     bool removeColumns(int column, int count, const QModelIndex &parent = QModelIndex());
  76.     bool removeRows(int row, int count, const QModelIndex &parent = QModelIndex());
  77.     bool insertRows(int row, int count, const QModelIndex &parent = QModelIndex());
  78.     bool insertRecord(int row, const QSqlRecord &record);
  79.     bool setRecord(int row, const QSqlRecord &record);
  80.     virtual void revertRow(int row);
  81. public Q_SLOTS:
  82.     bool submit();
  83.     void revert();
  84.     bool submitAll();
  85.     void revertAll();
  86. Q_SIGNALS:
  87.     void primeInsert(int row, QSqlRecord &record);
  88.     void beforeInsert(QSqlRecord &record);
  89.     void beforeUpdate(int row, QSqlRecord &record);
  90.     void beforeDelete(int row);
  91. protected:
  92.     QSqlTableModel(QSqlTableModelPrivate &dd, QObject *parent = 0, QSqlDatabase db = QSqlDatabase());
  93.     virtual bool updateRowInTable(int row, const QSqlRecord &values);
  94.     virtual bool insertRowIntoTable(const QSqlRecord &values);
  95.     virtual bool deleteRowFromTable(int row);
  96.     virtual QString orderByClause() const;
  97.     virtual QString selectStatement() const;
  98.     void setPrimaryKey(const QSqlIndex &key);
  99.     void setQuery(const QSqlQuery &query);
  100.     QModelIndex indexInQuery(const QModelIndex &item) const;
  101. };
  102. QT_END_NAMESPACE
  103. QT_END_HEADER
  104. #endif // QSQLTABLEMODEL_H