KDbQuerySchema

Search for usage in LXR

#include <KDbQuerySchema.h>

Inheritance diagram for KDbQuerySchema:

Public Types

enum class  ColumnsOrderMode { UnexpandedList , UnexpandedListWithoutAsterisks , ExpandedList }
 
enum class  ExpandMode { Unexpanded , Expanded }
 
enum class  FieldsExpandedMode { Default , Unique , WithInternalFields , WithInternalFieldsAndRecordId }
 

Public Member Functions

 KDbQuerySchema ()
 
 KDbQuerySchema (const KDbQuerySchema &querySchema, KDbConnection *conn)
 
 KDbQuerySchema (KDbTableSchema *tableSchema)
 
bool addAsterisk (KDbQueryAsterisk *asterisk)
 
bool addExpression (const KDbExpression &expr)
 
bool addField (KDbField *field)
 
bool addField (KDbField *field, int bindToTable)
 
bool addInvisibleAsterisk (KDbQueryAsterisk *asterisk)
 
bool addInvisibleExpression (const KDbExpression &expr)
 
bool addInvisibleField (KDbField *field)
 
bool addInvisibleField (KDbField *field, int bindToTable)
 
KDbRelationship * addRelationship (KDbField *field1, KDbField *field2)
 
void addTable (KDbTableSchema *table, const QString &alias=QString())
 
bool addToWhereExpression (KDbField *field, const QVariant &value, KDbToken relation='=', QString *errorMessage=nullptr, QString *errorDescription=nullptr)
 
KDbField::Listasterisks () const
 
KDbQueryColumnInfo::ListautoIncrementFields (KDbConnection *conn) const
 
KDbEscapedString autoIncrementSqlFieldsList (KDbConnection *conn) const
 
void clear () override
 
QString columnAlias (int position) const
 
int columnAliasesCount () const
 
KDbQueryColumnInfocolumnInfo (KDbConnection *conn, const QString &identifier, ExpandMode mode=ExpandMode::Expanded) const
 
int columnPositionForAlias (const QString &name) const
 
QHash< KDbQueryColumnInfo *, int > columnsOrder (KDbConnection *conn, ColumnsOrderMode mode=ColumnsOrderMode::ExpandedList) const
 
bool contains (KDbTableSchema *table) const
 
KDbQueryColumnInfoexpandedOrInternalField (KDbConnection *conn, int index) const
 
virtual KDbFieldfield (const QString &name)
 
virtual const KDbFieldfield (const QString &name) const
 
const KDbFieldfield (int id) const override
 
KDbFieldfield (int id) override
 
KDbFieldfield (KDbConnection *conn, const QString &identifier, ExpandMode mode=ExpandMode::Expanded)
 
const KDbFieldfield (KDbConnection *conn, const QString &identifier, ExpandMode mode=ExpandMode::Expanded) const
 
KDbQueryColumnInfo::Vector fieldsExpanded (KDbConnection *conn, FieldsExpandedMode mode=FieldsExpandedMode::Default) const
 
KDbFieldfindTableField (const QString &fieldOrTableAndFieldName) const
 
bool hasColumnAlias (const QString &name) const
 
bool hasColumnAlias (int position) const
 
bool hasTableAlias (const QString &name) const
 
bool hasTableAlias (int position) const
 
bool insertField (int position, KDbField *field) override
 
bool insertField (int position, KDbField *field, int bindToTable)
 
bool insertInvisibleField (int position, KDbField *field)
 
bool insertInvisibleField (int position, KDbField *field, int bindToTable)
 
KDbQueryColumnInfo::Vector internalFields (KDbConnection *conn) const
 
bool isColumnVisible (int position) const
 
KDbTableSchemamasterTable () const
 
KDbOrderByColumnListorderByColumnList ()
 
const KDbOrderByColumnListorderByColumnList () const
 
QList< KDbQuerySchemaParameterparameters (KDbConnection *conn) const
 
int pkeyFieldCount (KDbConnection *conn)
 
QVector< int > pkeyFieldsOrder (KDbConnection *conn) const
 
QList< KDbRelationship * > * relationships () const
 
bool removeField (KDbField *field) override
 
void removeTable (KDbTableSchema *table)
 
bool setColumnAlias (int position, const QString &alias)
 
void setColumnVisible (int position, bool visible)
 
void setMasterTable (KDbTableSchema *table)
 
void setOrderByColumnList (const KDbOrderByColumnList &list)
 
void setStatement (const KDbEscapedString &sql)
 
bool setTableAlias (int position, const QString &alias)
 
bool setWhereExpression (const KDbExpression &expr, QString *errorMessage=nullptr, QString *errorDescription=nullptr)
 
KDbEscapedString statement () const
 
KDbTableSchematable (const QString &tableName) const
 
QString tableAlias (const QString &tableName) const
 
QString tableAlias (int position) const
 
int tableAliasesCount () const
 
QString tableAliasOrName (const QString &tableName) const
 
int tableBoundToColumn (int columnPosition) const
 
int tablePosition (const QString &tableName) const
 
int tablePositionForAlias (const QString &name) const
 
QList< int > tablePositions (const QString &tableName) const
 
QList< KDbTableSchema * > * tables () const
 
bool validate (QString *errorMessage=nullptr, QString *errorDescription=nullptr)
 
KDbQueryColumnInfo::Vector visibleFieldsExpanded (KDbConnection *conn, FieldsExpandedMode options=FieldsExpandedMode::Default) const
 
KDbExpression whereExpression () const
 
- Public Member Functions inherited from KDbFieldList
 KDbFieldList (bool owner=false)
 
 KDbFieldList (const KDbFieldList &fl, bool deepCopyFields=true)
 
virtual ~KDbFieldList ()
 
bool addField (KDbField *field)
 
KDbField::ListautoIncrementFields () const
 
int fieldCount () const
 
KDbField::Listfields ()
 
const KDbField::Listfields () const
 
KDbField::ListIterator fieldsIterator () const
 
KDbField::ListIterator fieldsIteratorConstEnd () const
 
bool hasField (const KDbField &field) const
 
int indexOf (const KDbField &field) const
 
bool isEmpty () const
 
bool isOwner () const
 
virtual bool moveField (KDbField *field, int newIndex)
 
QStringList names () const
 
bool renameField (const QString &oldName, const QString &newName)
 
bool renameField (KDbField *field, const QString &newName)
 
KDbEscapedString sqlFieldsList (KDbConnection *conn, const QString &separator=QLatin1String(","), const QString &tableOrAlias=QString(), KDb::IdentifierEscapingType escapingType=KDb::DriverEscaping) const
 
KDbFieldListsubList (const QList< int > &list)
 
KDbFieldListsubList (const QList< QByteArray > &list)
 
KDbFieldListsubList (const QString &n1, const QString &n2=QString(), const QString &n3=QString(), const QString &n4=QString(), const QString &n5=QString(), const QString &n6=QString(), const QString &n7=QString(), const QString &n8=QString(), const QString &n9=QString(), const QString &n10=QString(), const QString &n11=QString(), const QString &n12=QString(), const QString &n13=QString(), const QString &n14=QString(), const QString &n15=QString(), const QString &n16=QString(), const QString &n17=QString(), const QString &n18=QString())
 
KDbFieldListsubList (const QStringList &list)
 
- Public Member Functions inherited from KDbObject
 KDbObject (int type)
 
QString captionOrName () const
 

Static Public Member Functions

static KDbEscapedString sqlColumnsList (const KDbQueryColumnInfo::List &infolist, KDbConnection *conn=nullptr, KDb::IdentifierEscapingType escapingType=KDb::DriverEscaping)
 
- Static Public Member Functions inherited from KDbFieldList
static KDbEscapedString sqlFieldsList (const KDbField::List &list, KDbConnection *conn, const QString &separator=QLatin1String(","), const QString &tableOrAlias=QString(), KDb::IdentifierEscapingType escapingType=KDb::DriverEscaping)
 

Protected Member Functions

bool addAsteriskInternal (KDbQueryAsterisk *asterisk, bool visible)
 
bool addExpressionInternal (const KDbExpression &expr, bool visible)
 
KDbQuerySchemaFieldsExpanded * computeFieldsExpanded (KDbConnection *conn) const
 
KDbQueryColumnInfo::Vector fieldsExpandedInternal (KDbConnection *conn, FieldsExpandedMode mode, bool onlyVisible) const
 
bool insertFieldInternal (int position, KDbField *field, int bindToTable, bool visible)
 
void setWhereExpressionInternal (const KDbExpression &expr)
 
- Protected Member Functions inherited from KDbObject

Protected Attributes

KDbQuerySchemaPrivate *const d
 

Additional Inherited Members

- Public Attributes inherited from KDbObject
QString caption
 
QString description
 
int id
 
QString name
 
int type
 

Detailed Description

KDbQuerySchema provides information about database query.

The query that can be executed using KDb-compatible SQL database engine or used as an introspection tool. KDb parser builds KDbQuerySchema objects by parsing SQL statements.

Definition at line 45 of file KDbQuerySchema.h.

Member Enumeration Documentation

◆ ColumnsOrderMode

Mode for columnsOrder()

Since
3.1
Enumerator
UnexpandedList 

A map for unexpanded list is created.

UnexpandedListWithoutAsterisks 

A map for unexpanded list is created, with asterisks skipped.

ExpandedList 

A map for expanded list is created.

Definition at line 525 of file KDbQuerySchema.h.

◆ ExpandMode

enum class KDbQuerySchema::ExpandMode
strong

Mode for field() and columnInfo()

Since
3.1
Enumerator
Unexpanded 

All fields are returned even if duplicated.

Expanded 

Expanded list of the query fields is computed so queries with asterisks are processed well.

Definition at line 386 of file KDbQuerySchema.h.

◆ FieldsExpandedMode

Mode for fieldsExpanded() and visibleFieldsExpanded()

Since
3.1
Enumerator
Default 

All fields are returned even if duplicated.

Unique 

Unique list of fields is returned.

WithInternalFields 

Like Default but internal fields (for lookup) are appended.

WithInternalFieldsAndRecordId 

Like WithInternalFields but record ID (big int type) field is appended after internal fields.

Definition at line 452 of file KDbQuerySchema.h.

Constructor & Destructor Documentation

◆ KDbQuerySchema() [1/3]

KDbQuerySchema::KDbQuerySchema ( )

Creates empty query object (without columns).

Definition at line 46 of file KDbQuerySchema.cpp.

◆ KDbQuerySchema() [2/3]

KDbQuerySchema::KDbQuerySchema ( KDbTableSchema * tableSchema)
explicit

Creates query schema object that is equivalent to "SELECT * FROM table" sql command. Schema of table is used to contruct this query – it is defined by just adding all the fields to the query in natural order. To avoid problems (e.g. with fields added outside of Kexi using ALTER TABLE) we do not use "all-tables query asterisk" (see KDbQueryAsterisk) item to achieve this effect.

Properties such as the name and caption of the query are inherited from table schema.

We consider that query schema based on table is not (a least yet) stored in a system table, so query connection is set to nullptr (even if tableSchema's connection is not nullptr). Id of the created query is set to 0.

Definition at line 53 of file KDbQuerySchema.cpp.

◆ KDbQuerySchema() [3/3]

KDbQuerySchema::KDbQuerySchema ( const KDbQuerySchema & querySchema,
KDbConnection * conn )

Copy constructor. Creates deep copy of querySchema. KDbQueryAsterisk objects are deeply copied while only pointers to KDbField objects are copied.

Definition at line 79 of file KDbQuerySchema.cpp.

◆ ~KDbQuerySchema()

KDbQuerySchema::~KDbQuerySchema ( )
override

Definition at line 103 of file KDbQuerySchema.cpp.

Member Function Documentation

◆ addAsterisk()

bool KDbQuerySchema::addAsterisk ( KDbQueryAsterisk * asterisk)

Appends asterisk at the and of columns list.

This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.

Sets the asterisk as invisible.

Since
3.1

Definition at line 304 of file KDbQuerySchema.cpp.

◆ addAsteriskInternal()

bool KDbQuerySchema::addAsteriskInternal ( KDbQueryAsterisk * asterisk,
bool visible )
protected

Internal method used by add*Asterisk() methods.

Appends asterisk at the and of columns list, sets visibility.

Definition at line 292 of file KDbQuerySchema.cpp.

◆ addExpression()

bool KDbQuerySchema::addExpression ( const KDbExpression & expr)

Appends a column built on top of expr expression.

This creates a new KDbField object and adds it to the query schema using addField().

This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.

In addition sets column's visibility to false.

Since
3.1

Definition at line 271 of file KDbQuerySchema.cpp.

◆ addExpressionInternal()

bool KDbQuerySchema::addExpressionInternal ( const KDbExpression & expr,
bool visible )
protected

Internal method used by all add*Expression methods.

Appends expression expr at the and of columns list, sets visibility.

Definition at line 255 of file KDbQuerySchema.cpp.

◆ addField() [1/2]

bool KDbQuerySchema::addField ( KDbField * field)

Appends field to the columns list.

The field will be visible. Use addInvisibleField(field) to add an invisible field. The field is not bound to any particular table within the query.

See also
insertField()

This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.

The field is not bound to any particular table within the query. In addition sets field's visibility to false. It will not be bound to any table in this query.

Since
3.1

Definition at line 216 of file KDbQuerySchema.cpp.

◆ addField() [2/2]

bool KDbQuerySchema::addField ( KDbField * field,
int bindToTable )

Appends field to the columns list. Also binds to a table at bindToTable position. Use bindToTable==-1 if no table should be bound. The field will be visible. Use addInvisibleField(field, bindToTable) to add an invisible field.

See also
insertField()
tableBoundToColumn(int columnPosition)

This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.

Also binds to a table at bindToTable position. In addition sets field's visibility to false.

See also
tableBoundToColumn(int columnPosition)
Since
3.1

Definition at line 221 of file KDbQuerySchema.cpp.

◆ addInvisibleAsterisk()

bool KDbQuerySchema::addInvisibleAsterisk ( KDbQueryAsterisk * asterisk)

Definition at line 309 of file KDbQuerySchema.cpp.

◆ addInvisibleExpression()

bool KDbQuerySchema::addInvisibleExpression ( const KDbExpression & expr)

Definition at line 276 of file KDbQuerySchema.cpp.

◆ addInvisibleField() [1/2]

bool KDbQuerySchema::addInvisibleField ( KDbField * field)

Definition at line 226 of file KDbQuerySchema.cpp.

◆ addInvisibleField() [2/2]

bool KDbQuerySchema::addInvisibleField ( KDbField * field,
int bindToTable )

Definition at line 231 of file KDbQuerySchema.cpp.

◆ addRelationship()

KDbRelationship * KDbQuerySchema::addRelationship ( KDbField * field1,
KDbField * field2 )

Appends a new relationship defined by field1 and field2. Both fields should belong to two different tables of this query. This is convenience function useful for a typical cases. It automatically creates KDbRelationship object for this query. If one of the fields are primary keys, it will be detected and appropriate master-detail relation will be established. This functiuon does nothing if the arguments are invalid.

Definition at line 1198 of file KDbQuerySchema.cpp.

◆ addTable()

void KDbQuerySchema::addTable ( KDbTableSchema * table,
const QString & alias = QString() )

Appends table schema as one of tables used in a query. If alias is not empty, it will be assigned to this table using setTableAlias(position, alias).

Definition at line 468 of file KDbQuerySchema.cpp.

◆ addToWhereExpression()

bool KDbQuerySchema::addToWhereExpression ( KDbField * field,
const QVariant & value,
KDbToken relation = '=',
QString * errorMessage = nullptr,
QString * errorDescription = nullptr )

Appends a part to WHERE expression.

Simplifies creating of WHERE expression if used instead of setWhereExpression().

Returns
false if the newly constructed WHERE expression is not valid. validate() is called to check this. On failure the WHERE expression for this query is left unchanged. In this case a string pointed by errorMessage (if provided) is set to a general error message and a string pointed by errorDescription (if provided) is set to a detailed description of the error.
Todo
date, time

Definition at line 1299 of file KDbQuerySchema.cpp.

◆ asterisks()

KDbField::List * KDbQuerySchema::asterisks ( ) const
Returns
list of KDbQueryAsterisk objects defined for this query. It is never nullptr.

Definition at line 669 of file KDbQuerySchema.cpp.

◆ autoIncrementFields()

KDbQueryColumnInfo::List * KDbQuerySchema::autoIncrementFields ( KDbConnection * conn) const
Returns
a list of field infos for all auto-incremented fields from master table of this query. This result is cached for efficiency. fieldsExpanded() is used for that.

Definition at line 1211 of file KDbQuerySchema.cpp.

◆ autoIncrementSqlFieldsList()

KDbEscapedString KDbQuerySchema::autoIncrementSqlFieldsList ( KDbConnection * conn) const
Returns
cached list of autoincrement fields created using sqlColumnsList() on a list returned by autoIncrementFields(). The field names are escaped using driver escaping.

Definition at line 1251 of file KDbQuerySchema.cpp.

◆ clear()

void KDbQuerySchema::clear ( )
overridevirtual

Removes all columns and their aliases from the columns list, removes all tables and their aliases from the tables list within this query. Sets master table information to nullptr. Does not destroy any objects though. Clears name and all other properties.

See also
KDbFieldList::clear()

Reimplemented from KDbFieldList.

Definition at line 108 of file KDbQuerySchema.cpp.

◆ columnAlias()

QString KDbQuerySchema::columnAlias ( int position) const
Returns
alias of a column at position or empty string if there is no alias for this column or if there is no such column within the query defined. If the column is an expression and has no alias defined, a new unique alias will be generated automatically on this call.

Definition at line 544 of file KDbQuerySchema.cpp.

◆ columnAliasesCount()

int KDbQuerySchema::columnAliasesCount ( ) const
Returns
number of column aliases

Definition at line 539 of file KDbQuerySchema.cpp.

◆ columnInfo()

KDbQueryColumnInfo * KDbQuerySchema::columnInfo ( KDbConnection * conn,
const QString & identifier,
ExpandMode mode = ExpandMode::Expanded ) const

Like KDbQuerySchema::field(const QString& name) but returns not only KDbField object for identifier but entire KDbQueryColumnInfo object. identifier can be:

  • a fieldname
  • an aliasname
  • a tablename.fieldname
  • a tablename.aliasname Note that if there are two occurrrences of the same name, only the first is accessible using this method. For instance, calling columnInfo("name") for "SELECT t1.name, t2.name FROM t1, t2" statement will only return the column related to t1.name and not t2.name, so you'll need to explicitly specify "t2.name" as the identifier to get the second column.

Definition at line 707 of file KDbQuerySchema.cpp.

◆ columnPositionForAlias()

int KDbQuerySchema::columnPositionForAlias ( const QString & name) const
Returns
column position that has defined alias name. If there is no such alias, -1 is returned.

Definition at line 637 of file KDbQuerySchema.cpp.

◆ columnsOrder()

QHash< KDbQueryColumnInfo *, int > KDbQuerySchema::columnsOrder ( KDbConnection * conn,
ColumnsOrderMode mode = ColumnsOrderMode::ExpandedList ) const
Returns
a hash for fast lookup of query columns' order.
  • If options is UnexpandedList, each KDbQueryColumnInfo pointer is mapped to the index within (unexpanded) list of fields, i.e. "*" or "table.*" asterisks are considered to be single items.
  • If options is UnexpandedListWithoutAsterisks, each KDbQueryColumnInfo pointer is mapped to the index within (unexpanded) list of columns that come from asterisks like "*" or "table.*" are not included in the map at all.
  • If options is ExpandedList (the default) this method provides is exactly opposite information compared to vector returned by fieldsExpanded().

This method's result is cached by the KDbQuerySchema object. Note: indices of internal fields (see internalFields()) are also returned here - in this case the index is counted as a sum of size(e) + i (where "e" is the list of expanded fields and i is the column index within internal fields list). This feature is used eg. at the end of KDbConnection::updateRecord() where need indices of fields (including internal) to update all the values in memory.

Example use: let t be table (int id, name text, surname text) and q be query defined by a statement "select * from t".

Definition at line 1146 of file KDbQuerySchema.cpp.

◆ computeFieldsExpanded()

KDbQuerySchemaFieldsExpanded * KDbQuerySchema::computeFieldsExpanded ( KDbConnection * conn) const
protected
Todo
(js): perhaps not all fields should be appended here
Todo
KDbQuerySchema itself will also support lookup fields...

Definition at line 804 of file KDbQuerySchema.cpp.

◆ contains()

bool KDbQuerySchema::contains ( KDbTableSchema * table) const
Returns
true if the query uses table.

Definition at line 513 of file KDbQuerySchema.cpp.

◆ expandedOrInternalField()

KDbQueryColumnInfo * KDbQuerySchema::expandedOrInternalField ( KDbConnection * conn,
int index ) const
Returns
info for expanded of internal field at index index. The returned field can be either logical or internal (for lookup), the latter case is true if index >= fieldsExpanded().count(). Equivalent of KDbQuerySchema::fieldsExpanded(WithInternalFields).at(index).

Definition at line 790 of file KDbQuerySchema.cpp.

◆ field() [1/6]

KDbField * KDbFieldList::field ( const QString & name)
virtual
Returns
field with name name or nullptr if there is no such a field.

Reimplemented from KDbFieldList.

Definition at line 89 of file KDbFieldList.cpp.

◆ field() [2/6]

const KDbField * KDbFieldList::field ( const QString & name) const
virtual

This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.

Reimplemented from KDbFieldList.

Definition at line 92 of file KDbFieldList.cpp.

◆ field() [3/6]

const KDbField * KDbQuerySchema::field ( int id) const
overridevirtual

Reimplemented from KDbFieldList.

Definition at line 702 of file KDbQuerySchema.cpp.

◆ field() [4/6]

KDbField * KDbQuerySchema::field ( int id)
overridevirtual
Returns
field id or nullptr if there is no such a field.

This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.

Reimplemented from KDbFieldList.

Definition at line 697 of file KDbQuerySchema.cpp.

◆ field() [5/6]

KDbField * KDbQuerySchema::field ( KDbConnection * conn,
const QString & identifier,
ExpandMode mode = ExpandMode::Expanded )

This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.

Definition at line 691 of file KDbQuerySchema.cpp.

◆ field() [6/6]

const KDbField * KDbQuerySchema::field ( KDbConnection * conn,
const QString & identifier,
ExpandMode mode = ExpandMode::Expanded ) const
Returns
field for identifier or nullptr if no field for this name was found within the query. fieldsExpanded() method is used to lookup expanded list of the query fields, so queries with asterisks are processed well. If a field has alias defined, name is not taken into account, but only its alias. If a field has no alias:
  • field's name is checked
  • field's table and field's name are checked in a form of "tablename.fieldname", so you can provide identifier in this form to avoid ambiguity.

If there are more than one fields with the same name equal to identifier, first-found is returned (checking is performed from first to last query field). Structures needed to compute result of this method are cached, so only first usage costs o(n) - another usages cost o(1).

Example: Let query be defined by "SELECT T.B AS X, T.* FROM T" statement and let T be table containing fields A, B, C. Expanded list of columns for the query is: T.B AS X, T.A, T.B, T.C.

  • Calling field("B") will return a pointer to third query column (not the first, because it is covered by "X" alias). Additionally, calling field("X") will return the same pointer.
  • Calling field("T.A") will return the same pointer as field("A").

This method is also a product of inheritance from KDbFieldList.

Definition at line 684 of file KDbQuerySchema.cpp.

◆ fieldsExpanded()

KDbQueryColumnInfo::Vector KDbQuerySchema::fieldsExpanded ( KDbConnection * conn,
FieldsExpandedMode mode = FieldsExpandedMode::Default ) const
inline
Returns
fully expanded list of fields. KDbQuerySchema::fields() returns vector of fields used for the query columns, but in a case when there are asterisks defined for the query, it does not expand KDbQueryAsterisk objects to field lists but return every asterisk as-is. This could be inconvenient when you need just a fully expanded list of fields, so this method does the work for you.

If options is Unique, each field is returned in the vector only once (first found field is selected). Note however, that the same field can be returned more than once if it has attached a different alias. For example, let t be TABLE( a, b ) and let query be defined by "SELECT *, a AS alfa FROM t" statement. Both fieldsExpanded(Default) and fieldsExpanded(Unique) will return [ a, b, a (alfa) ] list. On the other hand, for query defined by "SELECT *, a FROM t" statement, fieldsExpanded(Default) will return [ a, b, a ] list while fieldsExpanded(Unique) will return [ a, b ] list.

If options is WithInternalFields or WithInternalFieldsAndRecordID, additional internal fields are also appended to the vector.

If options is WithInternalFieldsAndRecordId, one fake BigInteger column is appended to make space for Record ID column used by KDbCursor implementations. For example, let city_id in TABLE persons(surname, city_id) reference cities.id in TABLE cities(id, name) and let query q be defined by "SELECT * FROM persons" statement. We want to display persons' city names instead of city_id's. To do this, cities.name has to be retrieved as well, so the following statement should be used: "SELECT * FROM persons, cities.name LEFT OUTER JOIN cities ON persons.city_id=cities.id". Thus, calling fieldsExpanded(WithInternalFieldsAndRecordId) will return 4 elements instead of 2: persons.surname, persons.city_id, cities.name, {ROWID}. The {ROWID} item is the placeholder used for fetching ROWID by KDb cursors.

By default, all fields are returned in the vector even if there are multiple occurrences of one or more (options == Default).

Note: You should assign the resulted vector in your space - it will be shared and implicity copied on any modification. This method's result is cached by KDbQuerySchema object.

Todo
js: UPDATE CACHE!

Definition at line 501 of file KDbQuerySchema.h.

◆ fieldsExpandedInternal()

KDbQueryColumnInfo::Vector KDbQuerySchema::fieldsExpandedInternal ( KDbConnection * conn,
FieldsExpandedMode mode,
bool onlyVisible ) const
protected

Used by fieldsExpanded(KDbConnection*, FieldsExpandedMode) and visibleFieldsExpanded(KDbConnection*, FieldsExpandedMode).

Definition at line 715 of file KDbQuerySchema.cpp.

◆ findTableField()

KDbField * KDbQuerySchema::findTableField ( const QString & fieldOrTableAndFieldName) const

Convenience function.

Returns
table field by searching through all tables in this query. The field does not need to be included on the list of query columns. Similarly, query aliases are not taken into account.

fieldOrTableAndFieldName string may contain table name and field name with '.' character between them, e.g. "mytable.myfield". This is recommended way to avoid ambiguity. 0 is returned if the query has no such table defined of the table has no such field defined. If you do not provide a table name, the first field found is returned.

KDbQuerySchema::table("mytable")->field("myfield") could be alternative for findTableField("mytable.myfield") but it can crash if "mytable" is not defined in the query.

See also
KDb::splitToTableAndFieldParts()

Definition at line 518 of file KDbQuerySchema.cpp.

◆ hasColumnAlias() [1/2]

bool KDbQuerySchema::hasColumnAlias ( const QString & name) const

Provided for convenience.

Returns
true if non empty alias name is defined for any column.

Definition at line 642 of file KDbQuerySchema.cpp.

◆ hasColumnAlias() [2/2]

bool KDbQuerySchema::hasColumnAlias ( int position) const

Provided for convenience.

Returns
true if a column at position has non empty alias defined within the query. If there is no alias for this column, or if there is no such column in the query defined, false is returned.

Definition at line 549 of file KDbQuerySchema.cpp.

◆ hasTableAlias() [1/2]

bool KDbQuerySchema::hasTableAlias ( const QString & name) const

Provided for convenience.

Returns
true if non empty table alias name is defined for a table.

Definition at line 632 of file KDbQuerySchema.cpp.

◆ hasTableAlias() [2/2]

bool KDbQuerySchema::hasTableAlias ( int position) const

Provided for convenience.

Returns
true if a table at position (within FROM section of the query) has non empty alias defined. If there is no alias for this table, or if there is no such table in the query defined, false is returned.

Definition at line 627 of file KDbQuerySchema.cpp.

◆ insertField() [1/2]

bool KDbQuerySchema::insertField ( int position,
KDbField * field )
overridevirtual

Inserts field to the columns list at position. Inserted field will not be owned by this KDbQuerySchema object, but by the corresponding KDbTableSchema.

KDbQueryAsterisk can be also passed as field. See the KDbQueryAsterisk class description.

Note
After inserting a field, corresponding table will be automatically added to query's tables list if it is not present there (see tables()). KDbField must have its table assigned.

The inserted field will be visible. Use insertInvisibleField(position, field) to add an invisible field.

The field is not bound to any particular table within the query.

This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.

bindToTable is a table index within the query for which the field should be bound. If bindToTable is -1, no particular table will be bound.

See also
tableBoundToColumn(int columnPosition)

This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.

In addition sets field's visibility to false. It will not be bound to any table in this query.

Since
3.1

Reimplemented from KDbFieldList.

Definition at line 116 of file KDbQuerySchema.cpp.

◆ insertField() [2/2]

bool KDbQuerySchema::insertField ( int position,
KDbField * field,
int bindToTable )

Definition at line 126 of file KDbQuerySchema.cpp.

◆ insertFieldInternal()

bool KDbQuerySchema::insertFieldInternal ( int position,
KDbField * field,
int bindToTable,
bool visible )
protected

Internal method used by all insert*Field methods.

The new column can also be explicitly bound to a specific position on tables list. bindToTable is a table index within the query for which the field should be bound. If bindToTable is -1, no particular table will be bound.

See also
tableBoundToColumn(int columnPosition)

Definition at line 136 of file KDbQuerySchema.cpp.

◆ insertInvisibleField() [1/2]

bool KDbQuerySchema::insertInvisibleField ( int position,
KDbField * field )

This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.

In addition sets field's visibility to false. bindToTable is a table index within the query for which the field should be bound. If bindToTable is -1, no particular table will be bound.

See also
tableBoundToColumn(int columnPosition)
Since
3.1

Definition at line 121 of file KDbQuerySchema.cpp.

◆ insertInvisibleField() [2/2]

bool KDbQuerySchema::insertInvisibleField ( int position,
KDbField * field,
int bindToTable )

Definition at line 131 of file KDbQuerySchema.cpp.

◆ internalFields()

KDbQueryColumnInfo::Vector KDbQuerySchema::internalFields ( KDbConnection * conn) const
Returns
list of internal fields used for lookup columns.

Definition at line 784 of file KDbQuerySchema.cpp.

◆ isColumnVisible()

bool KDbQuerySchema::isColumnVisible ( int position) const
Returns
visibility flag for column at position. By default column is visible.

Definition at line 281 of file KDbQuerySchema.cpp.

◆ masterTable()

KDbTableSchema * KDbQuerySchema::masterTable ( ) const
Returns
table that is master to this query. All potentially-editable columns within this query belong just to this table. This method also can return nullptr if there are no tables at all, or if previously assigned master table schema has been removed with removeTable(). Every query that has at least one table defined, should have assigned a master table. If no master table is assigned explicitly, but only one table used in this query, a single table is returned here, even if there are table aliases, (e.g. "T" table is returned for "SELECT T1.A, T2.B FROM T T1, T T2" statement).

Definition at line 436 of file KDbQuerySchema.cpp.

◆ orderByColumnList() [1/2]

KDbOrderByColumnList * KDbQuerySchema::orderByColumnList ( )
Returns
a list of columns listed in ORDER BY section of the query. Read notes for setOrderByColumnList().

Definition at line 1366 of file KDbQuerySchema.cpp.

◆ orderByColumnList() [2/2]

const KDbOrderByColumnList * KDbQuerySchema::orderByColumnList ( ) const
See also
orderByColumnList()

Definition at line 1371 of file KDbQuerySchema.cpp.

◆ parameters()

QList< KDbQuerySchemaParameter > KDbQuerySchema::parameters ( KDbConnection * conn) const
Returns
query schema parameters. These are taked from the WHERE section (a tree of expression items).

Definition at line 1376 of file KDbQuerySchema.cpp.

◆ pkeyFieldCount()

int KDbQuerySchema::pkeyFieldCount ( KDbConnection * conn)
Returns
number of master table's primary key fields included in this query. This method is useful to quickly check whether the vector returned by pkeyFieldsOrder() if filled completely.

User e.g. in KDbConnection::updateRecord() to check if entire primary key information is specified.

Examples: let table T has (ID1 INTEGER, ID2 INTEGER, A INTEGER) fields, and let (ID1, ID2) is T's primary key.

  1. The query defined by "SELECT * FROM T" statement contains all T's primary key's fields as T is the master table, and thus pkeyFieldCount() will return 2 (both primary key's fields are in the fieldsExpanded() list), and pkeyFieldsOrder() will return vector {0, 1}.
  2. The query defined by "SELECT A, ID2 FROM T" statement, and thus pkeyFieldCount() will return 1 (only one primary key's field is in the fieldsExpanded() list), and pkeyFieldsOrder() will return vector {-1, 1}, as second primary key's field is at position #1 and first field is not specified at all within the query.

Definition at line 1192 of file KDbQuerySchema.cpp.

◆ pkeyFieldsOrder()

QVector< int > KDbQuerySchema::pkeyFieldsOrder ( KDbConnection * conn) const
Returns
table describing order of primary key (PKEY) fields within the query. Indexing is performed against vector returned by fieldsExpanded(). It is usable for e.g. Connection::updateRecord(), when we need to locate each primary key's field in a constant time.

Returned vector is owned and cached by KDbQuerySchema object. When you assign it, it is implicity shared. Its size is equal to number of primary key fields defined for master table (masterTable()->primaryKey()->fieldCount()).

Each element of the returned vector:

If there are more than one primary key's field included in the query, only first-found column (oin the fieldsExpanded() list) for each pkey's field is included.

Returns empty vector if there is no master table or no master table's pkey.

See also
example for pkeyFieldCount().
Todo
js: UPDATE CACHE!

Definition at line 1158 of file KDbQuerySchema.cpp.

◆ relationships()

QList< KDbRelationship * > * KDbQuerySchema::relationships ( ) const
Returns
a list of relationships defined for this query. It is never nullptr.

Definition at line 664 of file KDbQuerySchema.cpp.

◆ removeField()

bool KDbQuerySchema::removeField ( KDbField * field)
overridevirtual

Removes field from the columns list. Use with care.

Todo
should we also remove table for this field or asterisk?

Reimplemented from KDbFieldList.

Definition at line 236 of file KDbQuerySchema.cpp.

◆ removeTable()

void KDbQuerySchema::removeTable ( KDbTableSchema * table)

Removes table schema from this query. This does not destroy table object but only takes it out of the list. If this table was master for the query, master table information is also invalidated.

Todo
remove fields!

Definition at line 492 of file KDbQuerySchema.cpp.

◆ setColumnAlias()

bool KDbQuerySchema::setColumnAlias ( int position,
const QString & alias )

Sets alias for a column at position, within the query. Passing empty string to alias clears alias for a given column.

Definition at line 554 of file KDbQuerySchema.cpp.

◆ setColumnVisible()

void KDbQuerySchema::setColumnVisible ( int position,
bool visible )

Sets visibility flag for column at position to visible.

Definition at line 286 of file KDbQuerySchema.cpp.

◆ setMasterTable()

void KDbQuerySchema::setMasterTable ( KDbTableSchema * table)

Sets master table of this query to table. This table should be also added to query's tables list using addTable(). If table equals nullptr, nothing is performed.

See also
masterTable()

Definition at line 457 of file KDbQuerySchema.cpp.

◆ setOrderByColumnList()

void KDbQuerySchema::setOrderByColumnList ( const KDbOrderByColumnList & list)

Sets a list of columns for ORDER BY section of the query. Each name on the list must be a field or alias present within the query and must not be covered by aliases. If one or more names cannot be found within the query, the method will have no effect. Any previous ORDER BY settings will be removed.

Note that this information is cleared whenever you call methods that modify list of columns (KDbQueryColumnInfo), i.e. insertField(), addField(), removeField(), addExpression(), etc. (because KDbOrderByColumn items can point to a KDbQueryColumnInfo that's removed by these methods), so you should use setOrderByColumnList() method after the query is completely built.

Definition at line 1359 of file KDbQuerySchema.cpp.

◆ setStatement()

void KDbQuerySchema::setStatement ( const KDbEscapedString & sql)

Forces a raw SQL statement sql for the query. This means that no statement is composed from KDbQuerySchema's content.

Definition at line 679 of file KDbQuerySchema.cpp.

◆ setTableAlias()

bool KDbQuerySchema::setTableAlias ( int position,
const QString & alias )

Sets alias for a table at position (within FROM section of the query). Passing empty sting to alias clears alias for a given table (only for specified position).

Definition at line 647 of file KDbQuerySchema.cpp.

◆ setWhereExpression()

bool KDbQuerySchema::setWhereExpression ( const KDbExpression & expr,
QString * errorMessage = nullptr,
QString * errorDescription = nullptr )

Sets a WHERE expression exp.

Previously set WHERE expression will be removed. A null expression (KDbExpression()) can be passed to remove existing WHERE expresssion.

Returns
false if expr is not a valid WHERE expression. validate() is called to check this. On failure the WHERE expression for this query is cleared. In this case a string pointed by errorMessage (if provided) is set to a general error message and a string pointed by errorDescription (if provided) is set to a detailed description of the error.

Definition at line 1275 of file KDbQuerySchema.cpp.

◆ setWhereExpressionInternal()

void KDbQuerySchema::setWhereExpressionInternal ( const KDbExpression & expr)
protected

Internal method used by a query parser.

◆ sqlColumnsList()

KDbEscapedString KDbQuerySchema::sqlColumnsList ( const KDbQueryColumnInfo::List & infolist,
KDbConnection * conn = nullptr,
KDb::IdentifierEscapingType escapingType = KDb::DriverEscaping )
static
Returns
a string that is a result of concatenating all column names for infolist, with "," between each one. This is usable e.g. as argument like "field1,field2" for "INSERT INTO (xxx) ..". The result of this method is effectively cached, and it is invalidated when set of fields changes (e.g. using clear() or addField()).

This method is similar to KDbFieldList::sqlFieldsList() it just uses KDbQueryColumnInfo::List instead of KDbField::List.

escapingType can be used to alter default escaping type. If conn is not provided for DriverEscaping, no escaping is performed.

Definition at line 1234 of file KDbQuerySchema.cpp.

◆ statement()

KDbEscapedString KDbQuerySchema::statement ( ) const
Returns
a preset statement (if any).

Definition at line 674 of file KDbQuerySchema.cpp.

◆ table()

KDbTableSchema * KDbQuerySchema::table ( const QString & tableName) const
Returns
table with name tableName or 0 if this query has no such table.
Todo
maybe use tables_byname?

Definition at line 502 of file KDbQuerySchema.cpp.

◆ tableAlias() [1/2]

QString KDbQuerySchema::tableAlias ( const QString & tableName) const
Returns
alias of a table tableName (within FROM section) or empty value if there is no alias for this table or if there is no such table within the query defined.

Definition at line 579 of file KDbQuerySchema.cpp.

◆ tableAlias() [2/2]

QString KDbQuerySchema::tableAlias ( int position) const
Returns
alias of a table at position (within FROM section) or null string if there is no alias for this table or if there is no such table within the query defined.

Definition at line 574 of file KDbQuerySchema.cpp.

◆ tableAliasesCount()

int KDbQuerySchema::tableAliasesCount ( ) const
Returns
number of table aliases

Definition at line 569 of file KDbQuerySchema.cpp.

◆ tableAliasOrName()

QString KDbQuerySchema::tableAliasOrName ( const QString & tableName) const
Returns
alias of a table tableName (within FROM section). If there is no alias for this table, its name is returned. Empty value is returned if there is no such table within the query defined.

Definition at line 588 of file KDbQuerySchema.cpp.

◆ tableBoundToColumn()

int KDbQuerySchema::tableBoundToColumn ( int columnPosition) const
Returns
a table position (within FROM section), that is bound to column at columnPosition (within SELECT section). This information can be used to find if there is alias defined for a table that is referenced by a given column.

For example, for "SELECT t2.id FROM table1 t1, table2 t2" query statement, columnBoundToTable(0) returns 1, what means that table at position 1 (within FROM section) is bound to column at position 0, so we can now call tableAlias(1) to see if we have used alias for this column (t2.id) or just a table name (table2.id).

These checks are performed e.g. by KDbConnection::selectStatement() to construct a statement string maximally identical to originally defined query statement.

-1 is returned if:

  • columnPosition is out of range (i.e. < 0 or >= fieldCount())
  • a column at columnPosition is not bound to any table (i.e. no database field is used for this column, e.g. "1" constant for "SELECT 1 from table" query statement)

Definition at line 206 of file KDbQuerySchema.cpp.

◆ tablePosition()

int KDbQuerySchema::tablePosition ( const QString & tableName) const
Returns
position (within the FROM section) of table tableName. -1 is returned if there's no such table declared in the FROM section.
See also
tablePositions()

Definition at line 602 of file KDbQuerySchema.cpp.

◆ tablePositionForAlias()

int KDbQuerySchema::tablePositionForAlias ( const QString & name) const
Returns
table position (within FROM section) that has attached alias name. If there is no such alias, -1 is returned. Only first table's position attached for this alias is returned. It is not especially bad, since aliases rarely can be duplicated, what leads to ambiguity. Duplicated aliases are only allowed for trivial queries that have no database fields used within their columns, e.g. "SELECT 1 from table1 t, table2 t" is ok but "SELECT t.id from table1 t, table2 t" is not.

Definition at line 597 of file KDbQuerySchema.cpp.

◆ tablePositions()

QList< int > KDbQuerySchema::tablePositions ( const QString & tableName) const
Returns
a list of all occurrences of table tableName (within the FROM section). E.g. for "SELECT * FROM table t, table t2" tablePositions("table") returns {0, 1} list. Empty list is returned if there's no table tableName used in the FROM section at all.
See also
tablePosition()

Definition at line 614 of file KDbQuerySchema.cpp.

◆ tables()

QList< KDbTableSchema * > * KDbQuerySchema::tables ( ) const
Returns
list of tables used in this query. It is never nullptr. The list also includes master table.
See also
masterTable()

Definition at line 463 of file KDbQuerySchema.cpp.

◆ validate()

bool KDbQuerySchema::validate ( QString * errorMessage = nullptr,
QString * errorDescription = nullptr )
Returns
true if this query is valid

Detailed validation is performed in the same way as parsing of query statements by the KDbParser. Example :Let the query be "SELECT <fields> FROM <tables> WHERE <whereExpression>". First each field from <fields> (

See also
fields()) is validated using KDbField::expression().validate(). Then the <whereExpression> (
whereExpression()) is validated using KDbExpression::validate().

On error a string pointed by errorMessage (if provided) is set to a general error message and a string pointed by errorDescription (if provided) is set to a detailed description of the error.

Todo
add tests

Definition at line 1393 of file KDbQuerySchema.cpp.

◆ visibleFieldsExpanded()

KDbQueryColumnInfo::Vector KDbQuerySchema::visibleFieldsExpanded ( KDbConnection * conn,
FieldsExpandedMode options = FieldsExpandedMode::Default ) const
inline

Like fieldsExpanded() but returns only visible fields.

Definition at line 508 of file KDbQuerySchema.h.

◆ whereExpression()

KDbExpression KDbQuerySchema::whereExpression ( ) const
Returns
WHERE expression or 0 if this query has no WHERE expression

Definition at line 1354 of file KDbQuerySchema.cpp.

Member Data Documentation

◆ d

KDbQuerySchemaPrivate* const KDbQuerySchema::d
protected

Definition at line 748 of file KDbQuerySchema.h.


The documentation for this class was generated from the following files:
This file is part of the KDE documentation.
Documentation copyright © 1996-2024 The KDE developers.
Generated on Mon Nov 18 2024 12:19:08 by doxygen 1.12.0 written by Dimitri van Heesch, © 1997-2006

KDE's Doxygen guidelines are available online.