23 : QAbstractItemModel( parent )
30 Q_ASSERT( mConnection );
35 : QAbstractItemModel( parent )
36 , mConnection( connection )
39 Q_ASSERT( mConnection );
43 void QgsDatabaseTableModel::init()
45 Q_ASSERT( mConnection->capabilities() & QgsAbstractDatabaseProviderConnection::Capability::Tables );
46 mTables = mConnection->tables( mSchema );
61 return mTables.count() + ( mAllowEmpty ? 1 : 0 );
73 if ( !
index.isValid() )
76 if (
index.row() == 0 && mAllowEmpty )
84 if (
index.row() - ( mAllowEmpty ? 1 : 0 ) >= mTables.count() )
105 case Qt::DecorationRole:
111 if ( role == Qt::DecorationRole )
117 if ( role == Qt::DecorationRole )
152 return static_cast< int >( table.
flags() );
167 if ( hasIndex( row, column,
parent ) )
169 return createIndex( row, column, row );
172 return QModelIndex();
177 if ( allowEmpty == mAllowEmpty )
182 beginInsertRows( QModelIndex(), 0, 0 );
188 beginRemoveRows( QModelIndex(), 0, 0 );
196 const QList< QgsAbstractDatabaseProviderConnection::TableProperty > newTables = mConnection->tables( mSchema );
197 const QList< QgsAbstractDatabaseProviderConnection::TableProperty > oldTables = mTables;
201 if ( !newTables.contains( oldTable ) )
203 int r = mTables.indexOf( oldTable );
204 beginRemoveRows( QModelIndex(), r + ( mAllowEmpty ? 1 : 0 ), r + ( mAllowEmpty ? 1 : 0 ) );
205 mTables.removeAt( r );
212 if ( !mTables.contains( newTable ) )
214 beginInsertRows( QModelIndex(), mTables.count() + ( mAllowEmpty ? 1 : 0 ), mTables.count() + ( mAllowEmpty ? 1 : 0 ) );
215 mTables.append( newTable );
The QgsAbstractDatabaseProviderConnection class provides common functionality for DB based connection...
QgsDatabaseTableModel(const QString &provider, const QString &connection, const QString &schema=QString(), QObject *parent=nullptr)
Constructor for QgsDatabaseTableModel, for the specified provider and connection name.
QModelIndex parent(const QModelIndex &child) const override
void refresh()
Refreshes the table list by querying the underlying connection.
QModelIndex index(int row, int column, const QModelIndex &parent) const override
void setAllowEmptyTable(bool allowEmpty)
Sets whether an optional empty table ("not set") option is present in the model.
int rowCount(const QModelIndex &parent=QModelIndex()) const override
int columnCount(const QModelIndex &parent=QModelIndex()) const override
@ RoleWkbType
WKB type for primary (first) geometry column in table.
@ RoleEmpty
Entry is an empty entry.
@ RoleCrs
CRS for primary (first) geometry column in table.
@ RoleCustomInfo
Custom info variant map role.
@ RoleTableName
Table name.
@ RoleTableFlags
Table flags role.
@ RoleComment
Comment role.
@ RoleSchema
Table schema.
QVariant data(const QModelIndex &index, int role=Qt::DisplayRole) const override
static QIcon iconLine()
Returns an icon representing line geometries.
static QIcon iconPolygon()
Returns an icon representing polygon geometries.
static QIcon iconPoint()
Returns an icon representing point geometries.
static QIcon iconTable()
Returns an icon representing non-spatial layers (tables).
static QgsProviderRegistry * instance(const QString &pluginPath=QString())
Means of accessing canonical single instance.
QgsProviderMetadata * providerMetadata(const QString &providerKey) const
Returns metadata of the provider or nullptr if not found.
static GeometryType geometryType(Type type) SIP_HOLDGIL
Returns the geometry type for a WKB type, e.g., both MultiPolygon and CurvePolygon would have a Polyg...
GeometryType
The geometry types are used to group QgsWkbTypes::Type in a coarse way.
The TableProperty class represents a database table or view.
QList< QgsAbstractDatabaseProviderConnection::TableProperty::GeometryColumnType > geometryColumnTypes() const
Returns the list of geometry column types and CRSs.
QString tableName() const
Returns the table name.
QVariantMap info() const
Returns additional information about the table.
QString comment() const
Returns the table comment.
QString schema() const
Returns the schema or an empty string for backends that do not support a schema.
TableFlags flags() const
Returns the table flags.