source: trunk/examples/sql/relationaltablemodel/relationaltablemodel.cpp@ 858

Last change on this file since 858 was 846, checked in by Dmitry A. Kuminov, 14 years ago

trunk: Merged in qt 4.7.2 sources from branches/vendor/nokia/qt.

File size: 4.1 KB
Line 
1/****************************************************************************
2**
3** Copyright (C) 2011 Nokia Corporation and/or its subsidiary(-ies).
4** All rights reserved.
5** Contact: Nokia Corporation ([email protected])
6**
7** This file is part of the examples of the Qt Toolkit.
8**
9** $QT_BEGIN_LICENSE:BSD$
10** You may use this file under the terms of the BSD license as follows:
11**
12** "Redistribution and use in source and binary forms, with or without
13** modification, are permitted provided that the following conditions are
14** met:
15** * Redistributions of source code must retain the above copyright
16** notice, this list of conditions and the following disclaimer.
17** * Redistributions in binary form must reproduce the above copyright
18** notice, this list of conditions and the following disclaimer in
19** the documentation and/or other materials provided with the
20** distribution.
21** * Neither the name of Nokia Corporation and its Subsidiary(-ies) nor
22** the names of its contributors may be used to endorse or promote
23** products derived from this software without specific prior written
24** permission.
25**
26** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
27** "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
28** LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
29** A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
30** OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
31** SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
32** LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
33** DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
34** THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
35** (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
36** OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE."
37** $QT_END_LICENSE$
38**
39****************************************************************************/
40
41#include <QtGui>
42#include <QtSql>
43
44#include "../connection.h"
45
46void initializeModel(QSqlRelationalTableModel *model)
47{
48//! [0]
49 model->setTable("employee");
50//! [0]
51
52 model->setEditStrategy(QSqlTableModel::OnManualSubmit);
53//! [1]
54 model->setRelation(2, QSqlRelation("city", "id", "name"));
55//! [1] //! [2]
56 model->setRelation(3, QSqlRelation("country", "id", "name"));
57//! [2]
58
59//! [3]
60 model->setHeaderData(0, Qt::Horizontal, QObject::tr("ID"));
61 model->setHeaderData(1, Qt::Horizontal, QObject::tr("Name"));
62 model->setHeaderData(2, Qt::Horizontal, QObject::tr("City"));
63 model->setHeaderData(3, Qt::Horizontal, QObject::tr("Country"));
64//! [3]
65
66 model->select();
67}
68
69QTableView *createView(const QString &title, QSqlTableModel *model)
70{
71//! [4]
72 QTableView *view = new QTableView;
73 view->setModel(model);
74 view->setItemDelegate(new QSqlRelationalDelegate(view));
75//! [4]
76 view->setWindowTitle(title);
77 return view;
78}
79
80void createRelationalTables()
81{
82 QSqlQuery query;
83 query.exec("create table employee(id int primary key, name varchar(20), city int, country int)");
84 query.exec("insert into employee values(1, 'Espen', 5000, 47)");
85 query.exec("insert into employee values(2, 'Harald', 80000, 49)");
86 query.exec("insert into employee values(3, 'Sam', 100, 1)");
87
88 query.exec("create table city(id int, name varchar(20))");
89 query.exec("insert into city values(100, 'San Jose')");
90 query.exec("insert into city values(5000, 'Oslo')");
91 query.exec("insert into city values(80000, 'Munich')");
92
93 query.exec("create table country(id int, name varchar(20))");
94 query.exec("insert into country values(1, 'USA')");
95 query.exec("insert into country values(47, 'Norway')");
96 query.exec("insert into country values(49, 'Germany')");
97}
98
99int main(int argc, char *argv[])
100{
101 QApplication app(argc, argv);
102 if (!createConnection())
103 return 1;
104 createRelationalTables();
105
106 QSqlRelationalTableModel model;
107
108 initializeModel(&model);
109
110 QTableView *view = createView(QObject::tr("Relational Table Model"), &model);
111 view->show();
112
113 return app.exec();
114}
Note: See TracBrowser for help on using the repository browser.