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

« back to all changes in this revision

Viewing changes to examples/sql/querymodel/editablesqlmodel.cpp

  • 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) 2004-2005 Trolltech AS. All rights reserved.
 
4
**
 
5
** This file is part of the example classes 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
#include <QtSql>
 
30
 
 
31
#include "editablesqlmodel.h"
 
32
 
 
33
EditableSqlModel::EditableSqlModel(QObject *parent)
 
34
    : QSqlQueryModel(parent)
 
35
{
 
36
}
 
37
 
 
38
Qt::ItemFlags EditableSqlModel::flags(
 
39
        const QModelIndex &index) const
 
40
{
 
41
    Qt::ItemFlags flags = QSqlQueryModel::flags(index);
 
42
    if (index.column() == 1 || index.column() == 2)
 
43
        flags |= Qt::ItemIsEditable;
 
44
    return flags;
 
45
}
 
46
 
 
47
bool EditableSqlModel::setData(const QModelIndex &index, const QVariant &value, int /* role */)
 
48
{
 
49
    if (index.column() < 1 || index.column() > 2)
 
50
        return false;
 
51
 
 
52
    QModelIndex primaryKeyIndex = QSqlQueryModel::index(index.row(), 0);
 
53
    int id = data(primaryKeyIndex).toInt();
 
54
 
 
55
    clear();
 
56
 
 
57
    bool ok;
 
58
    if (index.column() == 1) {
 
59
        ok = setFirstName(id, value.toString());
 
60
    } else {
 
61
        ok = setLastName(id, value.toString());
 
62
    }
 
63
    refresh();
 
64
    return ok;
 
65
}
 
66
 
 
67
void EditableSqlModel::refresh()
 
68
{
 
69
    setQuery("select * from person");
 
70
    setHeaderData(0, Qt::Horizontal, QObject::tr("ID"));
 
71
    setHeaderData(1, Qt::Horizontal, QObject::tr("First name"));
 
72
    setHeaderData(2, Qt::Horizontal, QObject::tr("Last name"));
 
73
}
 
74
 
 
75
bool EditableSqlModel::setFirstName(int personId, const QString &firstName)
 
76
{
 
77
    QSqlQuery query;
 
78
    query.prepare("update person set firstname = ? where id = ?");
 
79
    query.addBindValue(firstName);
 
80
    query.addBindValue(personId);
 
81
    return query.exec();
 
82
}
 
83
 
 
84
bool EditableSqlModel::setLastName(int personId, const QString &lastName)
 
85
{
 
86
    QSqlQuery query;
 
87
    query.prepare("update person set lastname = ? where id = ?");
 
88
    query.addBindValue(lastName);
 
89
    query.addBindValue(personId);
 
90
    return query.exec();
 
91
}