28 QStringList leftJoins;
33 columns <<
"t.geometry";
46 QString uid = QStringLiteral(
"uid" );
48 uid += QLatin1String(
"_" );
51 columns <<
"t.rowid AS " + uid;
56 for (
const auto &f : providerFields )
58 columns <<
"t.\"" + f.name() +
"\"";
64 QString joinName = QStringLiteral(
"j%1" ).arg( ++joinIdx );
68 QString prefix = join.
prefix().isEmpty() ? joinedLayer->
name() +
"_" : join.
prefix();
70 leftJoins << QStringLiteral(
"LEFT JOIN \"%1\" AS %2 ON t.\"%5\"=%2.\"%3\"" ).arg( joinedLayer->
id(), joinName, join.
joinFieldName(), join.
targetFieldName() );
75 columns << joinName +
".\"" + f +
"\" AS \"" + prefix + f +
"\"";
81 for (
const QgsField &f : joinFields )
85 columns << joinName +
".\"" + f.name() +
"\" AS \"" + prefix + f.name() +
"\"";
90 QString query =
"SELECT " + columns.join( QStringLiteral(
", " ) ) +
" FROM \"" + layer->
id() +
"\" AS t " + leftJoins.join( QStringLiteral(
" " ) );
const QList< QgsVectorLayerJoinInfo > vectorJoins() const
virtual QgsAttributeList pkAttributeIndexes() const
Returns list of indexes of fields that make up the primary key.
QString targetFieldName() const
Returns name of the field of our layer that will be used for join.
Container of fields for a vector layer.
bool isSpatial() const FINAL
Returns true if this is a geometry layer and false in case of NoGeometry (table only) or UnknownGeome...
QgsFields fields() const FINAL
Returns the list of fields of this layer.
void setQuery(const QString &query)
Sets the SQL query.
QgsFields fields() const override=0
Returns the fields associated with this data provider.
Defines left outer join from our vector layer to some other vector layer.
QString joinFieldName() const
Returns name of the field of joined layer that will be used for join.
QString id() const
Returns the layer's unique ID, which is used to access this layer from QgsProject.
static QgsVirtualLayerDefinition fromJoinedLayer(QgsVectorLayer *joinedLayer)
Gets a virtual layer definition from a vector layer where vector joins are replaced by SQL LEFT JOINs...
static QStringList joinFieldNamesSubset(const QgsVectorLayerJoinInfo &info, bool blacklisted=true)
Returns the list of field names to use for joining considering blacklisted fields and subset...
Encapsulate a field in an attribute table or data source.
int lookupField(const QString &fieldName) const
Looks up field's index from the field name.
QgsField field(int fieldIdx) const
Gets field at particular index (must be in range 0..N-1)
QString prefix() const
Returns prefix of fields from the joined layer. If null, joined layer's name will be used...
void setUid(const QString &uid)
Sets the name of the field with unique identifiers.
QgsVectorLayer * joinLayer() const
Returns joined layer (may be null if the reference was set by layer ID and not resolved yet) ...
QgsVectorDataProvider * dataProvider() FINAL
Returns the layer's data provider.
QList< int > QgsAttributeList
Represents a vector layer which manages a vector based data sets.
Class to manipulate the definition of a virtual layer.