qsqlrelationaltablemodel.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 QSQLRELATIONALTABLEMODEL_H
  38. #define QSQLRELATIONALTABLEMODEL_H
  39. #include <QtSql/qsqltablemodel.h>
  40. QT_BEGIN_HEADER
  41. QT_BEGIN_NAMESPACE
  42. QT_MODULE(Sql)
  43. class Q_SQL_EXPORT QSqlRelation
  44. {
  45. public:
  46.     QSqlRelation() {}
  47.     QSqlRelation(const QString &aTableName, const QString &indexCol,
  48.                const QString &displayCol)
  49.         : tName(aTableName), iColumn(indexCol), dColumn(displayCol) {}
  50.     inline QString tableName() const
  51.     { return tName; }
  52.     inline QString indexColumn() const
  53.     { return iColumn; }
  54.     inline QString displayColumn() const
  55.     { return dColumn; }
  56.     inline bool isValid() const
  57.     { return !(tName.isEmpty() || iColumn.isEmpty() || dColumn.isEmpty()); }
  58. private:
  59.     QString tName, iColumn, dColumn;
  60. };
  61. class QSqlRelationalTableModelPrivate;
  62. class Q_SQL_EXPORT QSqlRelationalTableModel: public QSqlTableModel
  63. {
  64.     Q_OBJECT
  65. public:
  66.     explicit QSqlRelationalTableModel(QObject *parent = 0,
  67.                                       QSqlDatabase db = QSqlDatabase());
  68.     virtual ~QSqlRelationalTableModel();
  69.     QVariant data(const QModelIndex &item, int role = Qt::DisplayRole) const;
  70.     bool setData(const QModelIndex &item, const QVariant &value, int role = Qt::EditRole);
  71.     bool removeColumns(int column, int count, const QModelIndex &parent = QModelIndex());
  72.     void clear();
  73.     bool select();
  74.     void setTable(const QString &tableName);
  75.     virtual void setRelation(int column, const QSqlRelation &relation);
  76.     QSqlRelation relation(int column) const;
  77.     virtual QSqlTableModel *relationModel(int column) const;
  78. public Q_SLOTS:
  79.     void revertRow(int row);
  80. protected:
  81.     QString selectStatement() const;
  82.     bool updateRowInTable(int row, const QSqlRecord &values);
  83.     bool insertRowIntoTable(const QSqlRecord &values);
  84.     QString orderByClause() const;
  85. private:
  86.     Q_DECLARE_PRIVATE(QSqlRelationalTableModel)
  87. };
  88. QT_END_NAMESPACE
  89. QT_END_HEADER
  90. #endif // QSQLRELATIONALTABLEMODEL_H