~oif-team/ubuntu/natty/qt4-x11/xi2.1

« back to all changes in this revision

Viewing changes to src/sql/models/qsqltablemodel.h

  • Committer: Bazaar Package Importer
  • Author(s): Adam Conrad
  • Date: 2005-08-24 04:09:09 UTC
  • Revision ID: james.westby@ubuntu.com-20050824040909-xmxe9jfr4a0w5671
Tags: upstream-4.0.0
ImportĀ upstreamĀ versionĀ 4.0.0

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/****************************************************************************
 
2
**
 
3
** Copyright (C) 1992-2005 Trolltech AS. All rights reserved.
 
4
**
 
5
** This file is part of the sql module of the Qt Toolkit.
 
6
**
 
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.
 
10
**
 
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.
 
15
**
 
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.
 
20
**
 
21
** Contact info@trolltech.com if any conditions of this licensing are
 
22
** not clear to you.
 
23
**
 
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.
 
26
**
 
27
****************************************************************************/
 
28
 
 
29
#ifndef QSQLTABLEMODEL_H
 
30
#define QSQLTABLEMODEL_H
 
31
 
 
32
#include "QtSql/qsqldatabase.h"
 
33
#include "QtSql/qsqlquerymodel.h"
 
34
 
 
35
class QSqlTableModelPrivate;
 
36
class QSqlRecord;
 
37
class QSqlField;
 
38
class QSqlIndex;
 
39
 
 
40
class Q_SQL_EXPORT QSqlTableModel: public QSqlQueryModel
 
41
{
 
42
    Q_OBJECT
 
43
    Q_DECLARE_PRIVATE(QSqlTableModel)
 
44
 
 
45
public:
 
46
    enum EditStrategy {OnFieldChange, OnRowChange, OnManualSubmit};
 
47
 
 
48
    explicit QSqlTableModel(QObject *parent = 0, QSqlDatabase db = QSqlDatabase());
 
49
    virtual ~QSqlTableModel();
 
50
 
 
51
    virtual bool select();
 
52
 
 
53
    virtual void setTable(const QString &tableName);
 
54
    QString tableName() const;
 
55
 
 
56
    Qt::ItemFlags flags(const QModelIndex &index) const;
 
57
 
 
58
    QVariant data(const QModelIndex &idx, int role = Qt::DisplayRole) const;
 
59
    bool setData(const QModelIndex &index, const QVariant &value, int role = Qt::EditRole);
 
60
 
 
61
    QVariant headerData(int section, Qt::Orientation orientation, int role = Qt::DisplayRole) const;
 
62
 
 
63
    bool isDirty(const QModelIndex &index) const;
 
64
    void clear();
 
65
 
 
66
    virtual void setEditStrategy(EditStrategy strategy);
 
67
    EditStrategy editStrategy() const;
 
68
 
 
69
    QSqlIndex primaryKey() const;
 
70
    QSqlDatabase database() const;
 
71
    int fieldIndex(const QString &fieldName) const;
 
72
 
 
73
    void sort(int column, Qt::SortOrder order);
 
74
    virtual void setSort(int column, Qt::SortOrder order);
 
75
 
 
76
    QString filter() const;
 
77
    virtual void setFilter(const QString &filter);
 
78
 
 
79
    int rowCount(const QModelIndex &parent = QModelIndex()) const;
 
80
 
 
81
    bool removeColumns(int column, int count, const QModelIndex &parent = QModelIndex());
 
82
    bool removeRows(int row, int count, const QModelIndex &parent = QModelIndex());
 
83
    bool insertRows(int row, int count, const QModelIndex &parent = QModelIndex());
 
84
 
 
85
    bool insertRecord(int row, const QSqlRecord &record);
 
86
    bool setRecord(int row, const QSqlRecord &record);
 
87
 
 
88
    virtual void revertRow(int row);
 
89
 
 
90
public slots:
 
91
    bool submit();
 
92
    void revert();
 
93
 
 
94
    bool submitAll();
 
95
    void revertAll();
 
96
 
 
97
signals:
 
98
    void primeInsert(int row, QSqlRecord &record);
 
99
 
 
100
    void beforeInsert(QSqlRecord &record);
 
101
    void beforeUpdate(int row, QSqlRecord &record);
 
102
    void beforeDelete(int row);
 
103
 
 
104
protected:
 
105
    QSqlTableModel(QSqlTableModelPrivate &dd, QObject *parent = 0, QSqlDatabase db = QSqlDatabase());
 
106
 
 
107
    virtual bool updateRowInTable(int row, const QSqlRecord &values);
 
108
    virtual bool insertRowIntoTable(const QSqlRecord &values);
 
109
    virtual bool deleteRowFromTable(int row);
 
110
    virtual QString orderByClause() const;
 
111
    virtual QString selectStatement() const;
 
112
 
 
113
    void setPrimaryKey(const QSqlIndex &key);
 
114
    void setQuery(const QSqlQuery &query);
 
115
    QModelIndex indexInQuery(const QModelIndex &item) const;
 
116
};
 
117
 
 
118
#endif // QSQLTABLEMODEL_H