kexi
KexiDB::TableSchema Class Reference
#include <tableschema.h>
Inheritance diagram for KexiDB::TableSchema:

Detailed Description
KexiDB::TableSchema provides information about native database table that can be stored using KexiDB database engine.
Definition at line 42 of file tableschema.h.
Public Types | |
typedef QPtrList< TableSchema > | List |
typedef QPtrListIterator< TableSchema > | ListIterator |
Public Member Functions | |
TableSchema (const QString &name) | |
TableSchema (const SchemaData &sdata) | |
TableSchema () | |
TableSchema (const TableSchema &ts, bool copyId=true) | |
TableSchema (const TableSchema &ts, int setId) | |
virtual | ~TableSchema () |
virtual FieldList & | insertField (uint index, Field *field) |
virtual void | removeField (KexiDB::Field *field) |
IndexSchema * | primaryKey () const |
void | setPrimaryKey (IndexSchema *pkey) |
const IndexSchema::ListIterator | indicesIterator () const |
const IndexSchema::List * | indices () |
virtual void | clear () |
QString | debugString (bool includeTableName) |
virtual QString | debugString () |
Connection * | connection () const |
bool | isKexiDBSystem () const |
void | setKexiDBSystem (bool set) |
virtual bool | isNative () const |
virtual void | setNative (bool set) |
QuerySchema * | query () |
Field * | anyNonPKField () |
bool | setLookupFieldSchema (const QString &fieldName, LookupFieldSchema *lookupFieldSchema) |
LookupFieldSchema * | lookupFieldSchema (const Field &field) const |
LookupFieldSchema * | lookupFieldSchema (const QString &fieldName) |
const QPtrVector< LookupFieldSchema > & | lookupFieldsList () |
Protected Member Functions | |
TableSchema (Connection *conn, const QString &name=QString::null) | |
Protected Attributes | |
IndexSchema::List | m_indices |
QGuardedPtr< Connection > | m_conn |
IndexSchema * | m_pkey |
QuerySchema * | m_query |
Private * | d |
Friends | |
class | Connection |
Member Typedef Documentation
typedef QPtrList<TableSchema> KexiDB::TableSchema::List |
typedef QPtrListIterator<TableSchema> KexiDB::TableSchema::ListIterator |
Constructor & Destructor Documentation
TableSchema::TableSchema | ( | const TableSchema & | ts, | |
bool | copyId = true | |||
) |
Copy constructor. if copyId is true, it's copied as well, otherwise the table id becomes -1, what is usable when we want to store the copy as an independent table.
Definition at line 92 of file tableschema.cpp.
TableSchema::TableSchema | ( | const TableSchema & | ts, | |
int | setId | |||
) |
Copy constructor like TableSchema(const TableSchema&, bool). setId is set as the table identifier. This is rarely usable, e.g. in project and data migration routines when we need to need deal with unique identifiers;
- See also:
- KexiMigrate::performImport().
Definition at line 99 of file tableschema.cpp.
TableSchema::TableSchema | ( | Connection * | conn, | |
const QString & | name = QString::null | |||
) | [protected] |
Automatically retrieves table schema via connection.
Definition at line 108 of file tableschema.cpp.
Member Function Documentation
Inserts field into a specified position (index). 'order' property of field is set automatically.
Reimplemented from KexiDB::FieldList.
Definition at line 184 of file tableschema.cpp.
void TableSchema::removeField | ( | KexiDB::Field * | field | ) | [virtual] |
Reimplemented for internal reasons.
Reimplemented from KexiDB::FieldList.
Definition at line 225 of file tableschema.cpp.
IndexSchema* KexiDB::TableSchema::primaryKey | ( | ) | const [inline] |
- Returns:
- list of fields that are primary key of this table. This method never returns 0 value, if there is no primary key, empty IndexSchema object is returned. IndexSchema object is owned by the table schema.
Definition at line 76 of file tableschema.h.
void TableSchema::setPrimaryKey | ( | IndexSchema * | pkey | ) |
Sets table's primary key index to pkey. Pass pkey==0 if you want to unassign existing primary key ("primary" property of given IndexSchema object will be cleared then so this index becomes ordinary index, still existing on table indeices list).
If this table already has primary key assigned, it is unassigned using setPrimaryKey(0) call.
Before assigning as primary key, you should add the index to indices list with addIndex() (this is not done automatically!).
Definition at line 163 of file tableschema.cpp.
void TableSchema::clear | ( | ) | [virtual] |
Removes all fields from the list, clears name and all other properties.
- See also:
- FieldList::clear()
Reimplemented from KexiDB::FieldList.
Definition at line 271 of file tableschema.cpp.
QString TableSchema::debugString | ( | bool | includeTableName | ) |
- Returns:
- String for debugging purposes, if includeTableName is true, table name, caption, etc. is prepended, else only debug string for the fields are returned.
Definition at line 331 of file tableschema.cpp.
QString TableSchema::debugString | ( | ) | [virtual] |
- Returns:
- String for debugging purposes. Equal to debugString(true).
Reimplemented from KexiDB::FieldList.
Definition at line 326 of file tableschema.cpp.
Connection* KexiDB::TableSchema::connection | ( | ) | const [inline] |
- Returns:
- connection object if table was created/retrieved using a connection, otherwise 0.
Definition at line 109 of file tableschema.h.
bool KexiDB::TableSchema::isKexiDBSystem | ( | ) | const [inline] |
- Returns:
- true if this is KexiDB storage system's table (used internally by KexiDB). This helps in hiding such tables in applications (if desired) and will also enable lookup of system tables for schema export/import functionality.
isKexiDBSystem()==true implies isNative()==true.
By default (after allocation), TableSchema object has this property set to false.
Definition at line 125 of file tableschema.h.
void TableSchema::setKexiDBSystem | ( | bool | set | ) |
Sets KexiDBSystem flag to on or off. When on, native flag is forced to be on. When off, native flag is not affected.
- See also:
- isKexiDBSystem()
Definition at line 347 of file tableschema.cpp.
virtual bool KexiDB::TableSchema::isNative | ( | ) | const [inline, virtual] |
- Returns:
- true if this is schema of native database object, When this is kexiDBSystem table, native flag is forced to be on.
Reimplemented from KexiDB::SchemaData.
Definition at line 134 of file tableschema.h.
QuerySchema * TableSchema::query | ( | ) |
- Returns:
- query schema object that is defined by "select * from <this_table_name>" This query schema object is owned by the table schema object. It is convenient way to get such a query when it is not available otherwise. Always returns non-0.
Definition at line 364 of file tableschema.cpp.
Field * TableSchema::anyNonPKField | ( | ) |
- Returns:
- any field not being a part of primary key of this table. If there is no such field, returns 0.
Definition at line 372 of file tableschema.cpp.
bool TableSchema::setLookupFieldSchema | ( | const QString & | fieldName, | |
LookupFieldSchema * | lookupFieldSchema | |||
) |
Sets lookup field schema lookupFieldSchema for fieldName. Passing null lookupFieldSchema will remove the previously set lookup field.
- Returns:
- true if lookupFieldSchema has been added, or false if there is no such field fieldName.
Definition at line 387 of file tableschema.cpp.
LookupFieldSchema * TableSchema::lookupFieldSchema | ( | const Field & | field | ) | const |
- Returns:
- lookup field schema for field. 0 is returned if there is no such field in the table or this field has no lookup schema. Note that even id non-zero is returned here, you may want to check whether lookup field's rowSource().name() is empty (if so, the field should behave as there was no lookup field defined at all).
Definition at line 405 of file tableschema.cpp.
const QPtrVector< LookupFieldSchema > & TableSchema::lookupFieldsList | ( | ) |
- Returns:
- list of lookup field schemas for this table. The order is the same as the order of fields within the table.
Definition at line 418 of file tableschema.cpp.
Member Data Documentation
QuerySchema* KexiDB::TableSchema::m_query [protected] |
cached query schema that is defined by "select * from <this_table_name>"
Definition at line 179 of file tableschema.h.
The documentation for this class was generated from the following files: