QSqlRelationalTableModel Class ReferenceThe QSqlRelationalTableModel class provides an editable data model for a single database table, with foreign key support. More... #include <QSqlRelationalTableModel> Inherits: QSqlTableModel. Public Types
Public Functions
Reimplemented Public Functions
Public Slots
Reimplemented Protected Functions
Additional Inherited Members
Detailed DescriptionThe QSqlRelationalTableModel class provides an editable data model for a single database table, with foreign key support. QSqlRelationalTableModel acts like QSqlTableModel, but allows columns to be set as foreign keys into other database tables. The screenshot on the left shows a plain QSqlTableModel in a QTableView. Foreign keys (city and country) aren't resolved to human-readable values. The screenshot on the right shows a QSqlRelationalTableModel, with foreign keys resolved into human-readable text strings. The following code snippet shows how the QSqlRelationalTableModel was set up: model->setTable("employee"); model->setRelation(2, QSqlRelation("city", "id", "name")); model->setRelation(3, QSqlRelation("country", "id", "name")); The setRelation() function calls establish a relationship between two tables. The first call specifies that column 2 in table employee is a foreign key that maps with field id of table city, and that the view should present the city's name field to the user. The second call does something similar with column 3. If you use a read-write QSqlRelationalTableModel, you probably want to use QSqlRelationalDelegate on the view. Unlike the default delegate, QSqlRelationalDelegate provides a combobox for fields that are foreign keys into other tables. To use the class, simply call QAbstractItemView::setItemDelegate() on the view with an instance of QSqlRelationalDelegate: QTableView *view = new QTableView; view->setModel(model); view->setItemDelegate(new QSqlRelationalDelegate(view)); The sql/relationaltablemodel example illustrates how to use QSqlRelationalTableModel in conjunction with QSqlRelationalDelegate to provide tables with foreigh key support. Notes:
See also QSqlRelation, QSqlRelationalDelegate, and Relational Table Model Example. Member Type Documentation
|
Constant | Value | Description |
---|---|---|
QSqlRelationalTableModel::InnerJoin | 0 | Inner join mode, return rows when there is at least one match in both tables. |
QSqlRelationalTableModel::LeftJoin | 1 | Left join mode, returns all rows from the left table (table_name1), even if there are no matches in the right table (table_name2). |
This enum was introduced or modified in Qt 4.8.
See also QSqlRelationalTableModel::setJoinMode().
Creates an empty QSqlRelationalTableModel and sets the parent to parent and the database connection to db. If db is not valid, the default database connection will be used.
Destroys the object and frees any allocated resources.
Reimplemented from QSqlQueryModel::clear().
Reimplemented from QAbstractItemModel::data().
See also setData().
Reimplemented from QSqlTableModel::insertRowIntoTable().
Reimplemented from QSqlTableModel::orderByClause().
Returns the relation for the column column, or an invalid relation if no relation is set.
See also setRelation() and QSqlRelation::isValid().
Returns a QSqlTableModel object for accessing the table for which column is a foreign key, or 0 if there is no relation for the given column.
The returned object is owned by the QSqlRelationalTableModel.
See also setRelation() and relation().
Reimplemented from QAbstractItemModel::removeColumns().
Reimplemented from QSqlTableModel::revertRow().
Reimplemented from QSqlTableModel::select().
Reimplemented from QSqlTableModel::selectStatement().
Reimplemented from QAbstractItemModel::setData().
Sets the data for the role in the item with the specified index to the value given. Depending on the edit strategy, the value might be applied to the database at once, or it may be cached in the model.
Returns true if the value could be set, or false on error (for example, if index is out of bounds).
For relational columns, value must be the index, not the display value. The index must also exist in the referenced table, otherwise the function returns false.
See also editStrategy(), data(), submit(), and revertRow().
Sets the SQL join mode to the value given by joinMode to show or hide rows with NULL foreign keys.
In InnerJoin mode (the default) these rows will not be shown; use the LeftJoin mode if you want to show them.
This function was introduced in Qt 4.8.
See also QSqlRelationalTableModel::JoinMode.
Lets the specified column be a foreign index specified by relation.
Example:
model->setTable("employee"); model->setRelation(2, QSqlRelation("city", "id", "name"));
The setRelation() call specifies that column 2 in table employee is a foreign key that maps with field id of table city, and that the view should present the city's name field to the user.
Note: The table's primary key may not contain a relation to another table.
See also relation().
Reimplemented from QSqlTableModel::setTable().
Reimplemented from QSqlTableModel::updateRowInTable().
Cette page est une traduction d'une page de la documentation de Qt, écrite par Nokia Corporation and/or its subsidiary(-ies). Les éventuels problèmes résultant d'une mauvaise traduction ne sont pas imputables à Nokia. | Qt 4.8 | |
Copyright © 2012 Developpez LLC. Tous droits réservés Developpez LLC. Aucune reproduction, même partielle, ne peut être faite de ce site et de l'ensemble de son contenu : textes, documents et images sans l'autorisation expresse de Developpez LLC. Sinon, vous encourez selon la loi jusqu'à 3 ans de prison et jusqu'à 300 000 E de dommages et intérêts. Cette page est déposée à la SACD. | ||
Vous avez déniché une erreur ? Un bug ? Une redirection cassée ? Ou tout autre problème, quel qu'il soit ? Ou bien vous désirez participer à ce projet de traduction ? N'hésitez pas à nous contacter ou par MP ! |
Copyright © 2000-2012 - www.developpez.com