QGIS API Documentation
3.16.0-Hannover (43b64b13f3)
|
Go to the documentation of this file.
20 #include <QStringList>
30 : mFilter( FilterFid )
36 : mFilter( FilterFids )
48 : mFilter( FilterExpression )
50 , mExpressionContext( context )
208 const auto constAttrNames = attrNames;
209 for (
const QString &attrName : constAttrNames )
212 if ( attrNum != -1 && !
mAttrs.contains( attrNum ) )
230 const auto constAttrNames = attrNames;
231 for (
const QString &attrName : constAttrNames )
234 if ( attrNum != -1 && !
mAttrs.contains( attrNum ) )
364 : mExpression( expression )
365 , mAscending( ascending )
372 : mExpression( expression )
373 , mAscending( ascending )
374 , mNullsFirst( nullsfirst )
379 : mExpression( expression )
380 , mAscending( ascending )
387 : mExpression( expression )
388 , mAscending( ascending )
389 , mNullsFirst( nullsfirst )
401 mAscending = ascending;
411 mNullsFirst = nullsFirst;
416 return QStringLiteral(
"%1 %2 %3" )
417 .arg( mExpression.expression(),
418 mAscending ?
"ASC" :
"DESC",
419 mNullsFirst ?
"NULLS FIRST" :
"NULLS LAST" );
429 return mExpression.prepare( context );
436 const auto constOther = other;
450 QDomDocument doc = elem.ownerDocument();
451 QList<OrderByClause>::ConstIterator it;
452 for ( it = constBegin(); it != constEnd(); ++it )
455 QDomElement clauseElem = doc.createElement( QStringLiteral(
"orderByClause" ) );
456 clauseElem.setAttribute( QStringLiteral(
"asc" ), clause.
ascending() );
457 clauseElem.setAttribute( QStringLiteral(
"nullsFirst" ), clause.
nullsFirst() );
460 elem.appendChild( clauseElem );
468 QDomNodeList clauses = elem.childNodes();
470 for (
int i = 0; i < clauses.size(); ++i )
472 QDomElement clauseElem = clauses.at( i ).toElement();
473 QString expression = clauseElem.text();
474 bool asc = clauseElem.attribute( QStringLiteral(
"asc" ) ).toInt() != 0;
475 bool nullsFirst = clauseElem.attribute( QStringLiteral(
"nullsFirst" ) ).toInt() != 0;
483 QSet<QString> usedAttributes;
485 QList<OrderByClause>::ConstIterator it;
486 for ( it = constBegin(); it != constEnd(); ++it )
493 return usedAttributes;
498 QSet<int> usedAttributeIdx;
502 for (
const QString &fieldName : referencedColumns )
507 usedAttributeIdx.insert( idx );
511 return usedAttributeIdx;
518 QList<OrderByClause>::ConstIterator it;
519 for ( it = constBegin(); it != constEnd(); ++it )
523 results << clause.
dump();
526 return results.join( QLatin1String(
", " ) );
QgsSimplifyMethod mSimplifyMethod
Expression contexts are used to encapsulate the parameters around which a QgsExpression should be eva...
The OrderByClause class represents an order by clause for a QgsFeatureRequest.
@ FilterFid
Filter using feature ID.
QgsExpression expression() const
The expression.
InvalidGeometryCheck mInvalidGeometryFilter
QgsFeatureRequest & setInvalidGeometryCheck(InvalidGeometryCheck check)
Sets invalid geometry checking behavior.
Contains information about the context in which a coordinate transform is executed.
This class contains information about how to simplify geometries fetched from a QgsFeatureIterator.
QgsFeatureIds mFilterFids
QgsFeatureRequest & addOrderBy(const QString &expression, bool ascending=true)
Adds a new OrderByClause, appending it as the least important one.
QgsCoordinateTransformContext transformContext() const
Returns the transform context, for use when a destinationCrs() has been set and reprojection is requi...
@ ExactIntersect
Use exact geometry intersection (slower) instead of bounding boxes.
bool acceptFeature(const QgsFeature &feature)
Check if a feature is accepted by this requests filter.
virtual ~QgsAbstractFeatureSource()
QSet< QString > referencedColumns() const
Gets list of columns referenced by the expression.
CORE_EXPORT OrderBy()
Create a new empty order by.
void setAscending(bool ascending)
Set if ascending order is requested.
#define QgsDebugMsgLevel(str, level)
void CORE_EXPORT save(QDomElement &elem) const
Serialize to XML.
QgsFeatureRequest & operator=(const QgsFeatureRequest &rh)
Assignment operator.
const Flags & flags() const
int timeout() const
Returns the timeout (in milliseconds) for the maximum time we should wait during feature requests bef...
const QgsCoordinateReferenceSystem & crs
QgsCoordinateReferenceSystem mCrs
Container of fields for a vector layer.
@ FilterFids
Filter using feature IDs.
QSet< QgsAbstractFeatureIterator * > mActiveIterators
QgsFeatureRequest & setInvalidGeometryCallback(const std::function< void(const QgsFeature &)> &callback)
Sets a callback function to use when encountering an invalid geometry and invalidGeometryCheck() is s...
QgsCoordinateReferenceSystem destinationCrs() const
Returns the destination coordinate reference system for feature's geometries, or an invalid QgsCoordi...
QgsFeatureRequest & setSubsetOfAttributes(const QgsAttributeList &attrs)
Set a subset of attributes that will be fetched.
InvalidGeometryCheck
Handling of features with invalid geometries.
QList< int > QgsAttributeList
bool prepare(QgsExpressionContext *context)
Prepare the expression with the given context.
A rectangle specified with double values.
@ SubsetOfAttributes
Fetch only a subset of attributes (setSubsetOfAttributes sets this flag)
QSet< QString > CORE_EXPORT usedAttributes() const
Returns a set of used attributes.
QgsFeatureRequest & setExpressionContext(const QgsExpressionContext &context)
Sets the expression context used to evaluate filter expressions.
QgsFeatureRequest & setFilterFid(QgsFeatureId fid)
Sets feature ID that should be fetched.
QgsFeatureRequest & setFilterExpression(const QString &expression)
Set the filter expression.
void setNullsFirst(bool nullsFirst)
Set if NULLS should be returned first.
QgsFeatureRequest()
construct a default request: for all features get attributes and geometries
QString dump() const
Dumps the content to an SQL equivalent.
QgsExpressionContext mExpressionContext
QgsFeatureRequest & setFilterRect(const QgsRectangle &rectangle)
Sets the rectangle from which features will be taken.
static const QString ALL_ATTRIBUTES
A special attribute that if set matches all attributes.
This class wraps a request for features to a vector layer (or directly its vector data provider).
bool intersects(const QgsRectangle &rectangle) const
Returns true if this geometry exactly intersects with a rectangle.
Q_DECL_DEPRECATED QgsFeatureRequest & setConnectionTimeout(int connectionTimeout)
Sets the timeout (in milliseconds) for how long we should wait for a connection if none is available ...
std::unique_ptr< QgsExpression > mFilterExpression
QgsFeatureRequest & combineFilterExpression(const QString &expression)
Modifies the existing filter expression to add an additional expression filter.
QgsFeatureRequest & setTransformErrorCallback(const std::function< void(const QgsFeature &)> &callback)
Sets a callback function to use when encountering a transform error when iterating features and a des...
bool ascending() const
Order ascending.
void CORE_EXPORT load(const QDomElement &elem)
Deserialize from XML.
bool requestMayBeNested() const
In case this request may be run nested within another already running iteration on the same connectio...
QgsFeatureRequest & setFilterFids(const QgsFeatureIds &fids)
Sets feature IDs that should be fetched.
void iteratorClosed(QgsAbstractFeatureIterator *it)
QgsCoordinateTransformContext mTransformContext
QgsFeatureRequest & setSimplifyMethod(const QgsSimplifyMethod &simplifyMethod)
Set a simplification method for geometries that will be fetched.
@ FilterExpression
Filter using expression.
QgsFeatureRequest & setTimeout(int timeout)
Sets the timeout (in milliseconds) for the maximum time we should wait during feature requests before...
QgsFeatureRequest & setNoAttributes()
Set that no attributes will be fetched.
QSet< QgsFeatureId > QgsFeatureIds
This class represents a coordinate reference system (CRS).
QSet< int > CORE_EXPORT usedAttributeIndices(const QgsFields &fields) const
Returns a set of used, validated attribute indices.
std::function< void(const QgsFeature &) > mInvalidGeometryCallback
OrderByClause(const QString &expression, bool ascending=true)
Creates a new OrderByClause for a QgsFeatureRequest.
bool nullsFirst() const
Set if NULLS should be returned first.
QgsFeatureRequest & setRequestMayBeNested(bool requestMayBeNested)
In case this request may be run nested within another already running iteration on the same connectio...
Represents a list of OrderByClauses, with the most important first and the least important last.
OrderBy orderBy() const
Returns a list of order by clauses specified for this feature request.
bool hasGeometry() const
Returns true if the feature has an associated geometry.
QgsFeatureRequest & setLimit(long limit)
Set the maximum number of features to request.
QList< QgsFeatureRequest::OrderByClause > CORE_EXPORT list() const
Gets a copy as a list of OrderByClauses.
void iteratorOpened(QgsAbstractFeatureIterator *it)
QString CORE_EXPORT dump() const
Dumps the content to an SQL equivalent syntax.
std::function< void(const QgsFeature &) > mTransformErrorCallback
const QgsSimplifyMethod & simplifyMethod() const
Gets simplification method for geometries that will be fetched.
QgsFeatureRequest & setOrderBy(const OrderBy &orderBy)
Set a list of order by clauses.
Q_DECL_DEPRECATED int connectionTimeout() const
Returns the timeout (in milliseconds) for how long we should wait for a connection if none is availab...
@ FilterNone
No filter is applied.
The feature class encapsulates a single feature including its id, geometry and a list of field/values...
QgsFeatureRequest & setDestinationCrs(const QgsCoordinateReferenceSystem &crs, const QgsCoordinateTransformContext &context)
Sets the destination crs for feature's geometries.
int lookupField(const QString &fieldName) const
Looks up field's index from the field name.
Class for parsing and evaluation of expressions (formerly called "search strings").
QgsFeatureRequest & setFlags(QgsFeatureRequest::Flags flags)
Sets flags that affect how features will be fetched.
Internal feature iterator to be implemented within data providers.
QString expression() const
Returns the original, unmodified expression string.
virtual bool close()=0
end of iterating: free the resources / lock
bool isNull() const
Test if the rectangle is null (all coordinates zero or after call to setMinimal()).
bool boundingBoxIntersects(const QgsRectangle &rectangle) const
Returns true if the bounding box of this geometry intersects with a rectangle.
qint64 QgsFeatureId
64 bit feature ids negative numbers are used for uncommitted/newly added features
void setFeature(const QgsFeature &feature)
Convenience function for setting a feature for the context.
long limit() const
Returns the maximum number of features to request, or -1 if no limit set.