File indexing completed on 2024-09-08 10:13:04

0001 /* This file is part of the KDE project
0002    Copyright (C) 2004-2015 Jarosław Staniek <staniek@kde.org>
0003 
0004    This library is free software; you can redistribute it and/or
0005    modify it under the terms of the GNU Library General Public
0006    License as published by the Free Software Foundation; either
0007    version 2 of the License, or (at your option) any later version.
0008 
0009    This library is distributed in the hope that it will be useful,
0010    but WITHOUT ANY WARRANTY; without even the implied warranty of
0011    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
0012    Library General Public License for more details.
0013 
0014    You should have received a copy of the GNU Library General Public License
0015    along with this library; see the file COPYING.LIB.  If not, write to
0016    the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
0017  * Boston, MA 02110-1301, USA.
0018 */
0019 
0020 #ifndef KDBTABLEORQUERYSCHEMA_H
0021 #define KDBTABLEORQUERYSCHEMA_H
0022 
0023 #include <QByteArray>
0024 
0025 #include "KDbQueryColumnInfo.h"
0026 
0027 class KDbConnection;
0028 class KDbFieldList;
0029 class KDbTableSchema;
0030 class KDbQuerySchema;
0031 
0032 /*! Variant class providing a pointer to table or query. */
0033 class KDB_EXPORT KDbTableOrQuerySchema
0034 {
0035 public:
0036     //! Type of object: table or query
0037     //! @since 3.1
0038     enum class Type {
0039         Table,
0040         Query
0041     };
0042 
0043     /*! Creates a new KDbTableOrQuerySchema variant object, retrieving table or query schema
0044      using @a conn connection and @a name. If both table and query exists for @a name,
0045      table has priority over query.
0046      Check whether a query or table has been found by testing (query() || table()) expression. */
0047     KDbTableOrQuerySchema(KDbConnection *conn, const QByteArray& name);
0048 
0049     /*! Creates a new KDbTableOrQuerySchema variant object, retrieving table or query schema
0050      using @a conn connection and @a name. If @a type is Table, @a name is assumed
0051      to be a table name, otherwise @a name is assumed to be a query name.
0052      Check whether a query or table has been found by testing (query() || table()) expression.
0053      @since 3.1 */
0054     KDbTableOrQuerySchema(KDbConnection *conn, const QByteArray &name, Type type);
0055 
0056     /*! Creates a new KDbTableOrQuerySchema variant object. @a tableOrQuery should be of
0057      class KDbTableSchema or KDbQuerySchema.
0058      Check whether a query or table has been found by testing (query() || table()) expression. */
0059     explicit KDbTableOrQuerySchema(KDbFieldList *tableOrQuery);
0060 
0061     /*! Creates a new KDbTableOrQuerySchema variant object, retrieving table or query schema
0062      using @a conn connection and @a id.
0063      Check whether a query or table has been found by testing (query() || table()) expression. */
0064     KDbTableOrQuerySchema(KDbConnection *conn, int id);
0065 
0066     /*! Creates a new KDbTableOrQuerySchema variant object, keeping a pointer to @a table
0067      object. */
0068     explicit KDbTableOrQuerySchema(KDbTableSchema* table);
0069 
0070     /*! Creates a new KDbTableOrQuerySchema variant object, keeping a pointer to @a query
0071      object. */
0072     explicit KDbTableOrQuerySchema(KDbQuerySchema* query);
0073 
0074     ~KDbTableOrQuerySchema();
0075 
0076     //! @return a pointer to the query if it's provided
0077     KDbQuerySchema* query() const;
0078 
0079     //! @return a pointer to the table if it's provided
0080     KDbTableSchema* table() const;
0081 
0082     //! @return name of a query or table
0083     QByteArray name() const;
0084 
0085     //! @return caption (if present) or name of the table/query
0086     QString captionOrName() const;
0087 
0088     /**
0089      * @brief Returns number of columns within record set returned from specified table or query
0090      *
0091      * In case of query expanded fields list is counted.
0092      * For tables @a conn is not required.
0093      * Returns -1 if the object has neither table or query assigned.
0094      * Returns -1 if the object has query assigned but @a conn is @c nullptr.
0095      */
0096     int fieldCount(KDbConnection *conn) const;
0097 
0098     /*! Mode for columns(). */
0099     enum class ColumnsMode {
0100         NonUnique, //!< Non-unique columns are returned
0101         Unique     //!< Unique columns are returned
0102     };
0103 
0104     //! @return all columns for the table or the query
0105     const KDbQueryColumnInfo::Vector columns(KDbConnection *conn, ColumnsMode mode = ColumnsMode::NonUnique);
0106 
0107     /*! @return a field of the table or the query schema for name @a name
0108      or 0 if there is no such field. */
0109     KDbField* field(const QString& name);
0110 
0111     /*! Like KDbField* field(const QString& name);
0112      but returns all information associated with field/column @a name. */
0113     KDbQueryColumnInfo* columnInfo(KDbConnection *conn, const QString& name);
0114 
0115 private:
0116     class Private;
0117     Private * const d;
0118 
0119     Q_DISABLE_COPY(KDbTableOrQuerySchema)
0120 };
0121 
0122 //! A pair (connection, table-or-schema) for QDebug operator<<
0123 //! @since 3.1
0124 typedef std::tuple<KDbConnection*, const KDbTableOrQuerySchema&> KDbConnectionAndSchema;
0125 
0126 //! Sends information about table or query schema and connection @a connectionAndSchema to debug output @a dbg.
0127 //! @since 3.1
0128 KDB_EXPORT QDebug operator<<(QDebug dbg, const KDbConnectionAndSchema &connectionAndSchema);
0129 
0130 #endif