1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74
|
#ifndef QUERYGENERATOR_H
#define QUERYGENERATOR_H
#include "common/column.h"
#include "common/bistrhash.h"
#include "schemaresolver.h"
#include "common/strhash.h"
#include <QString>
#include <QVariant>
class Db;
class API_EXPORT QueryGenerator
{
public:
QueryGenerator();
/**
* @brief Generates select of all column from the \p table having given column values matched.
* @overload
*/
QString generateSelectFromTable(Db* db, const QString& table, const StrHash<QVariantList> values = StrHash<QVariantList>());
/**
* @brief Generates SELECT of all column from the \p table having given column values matched.
* @param db Database where the \p table exists.
* @param database Attach name of the database (such as "main" or "temp", or any other used for ATTACH).
* @param table Table to generate select for.
* @param values Values to comply with.
* @return SELECT statement string.
*
* Generates SELECT for given table, listing all result columns explicitly and adding WHERE clause (if \p values is not empty) with columns included in \p values
* having any of values specified for those columns in that parameter.
*
* If \p values is ommited, then no WHERE clause is added.
*/
QString generateSelectFromTable(Db* db, const QString& database, const QString& table, const StrHash<QVariantList> values = StrHash<QVariantList>());
QString generateInsertToTable(Db* db, const QString& table, const StrHash<QVariantList> values = StrHash<QVariantList>());
QString generateInsertToTable(Db* db, const QString& database, const QString& table, StrHash<QVariantList> values = StrHash<QVariantList>());
QString generateUpdateOfTable(Db* db, const QString& table, const StrHash<QVariantList> values = StrHash<QVariantList>());
QString generateUpdateOfTable(Db* db, const QString& database, const QString& table, StrHash<QVariantList> values = StrHash<QVariantList>());
QString generateDeleteFromTable(Db* db, const QString& table, const StrHash<QVariantList> values = StrHash<QVariantList>());
QString generateDeleteFromTable(Db* db, const QString& database, const QString& table, StrHash<QVariantList> values = StrHash<QVariantList>());
QString generateSelectFromView(Db* db, const QString& view, const StrHash<QVariantList> values = StrHash<QVariantList>());
QString generateSelectFromView(Db* db, const QString& database, const QString& view, const StrHash<QVariantList> values = StrHash<QVariantList>());
/**
* @brief Generates SELECT for all columns from the \p initialSelect having values matched.
* @param db Database that will be used to resolve tables used in the \p initialSelect
* @param initialSelect The SELECT statement that will be used as a base for generating new query.
* @param values Map of column names and values for them, so the WHERE clause is generated for them.
* @param dbNameToAttach If the \p initialSelect uses attached databases, they should be provided in this parameter, so their symbolic names can be resolved to real attach name.
* @return Generated SELECT statement string.
*
* Generates SELECT using \p initialSelect as a base. Lists all columns from \p initialSelect result columns explicitly (no star operator).
* If there are \p values given, then the WHERE clause is added for them to match columns.
*/
QString generateSelectFromSelect(Db* db, const QString& initialSelect, const StrHash<QVariantList> values = StrHash<QVariantList>(), const BiStrHash& dbNameToAttach = BiStrHash());
private:
QString generateSelectFromTableOrView(Db* db, const QString& database, const QString& tableOrView, const QStringList& columns, const StrHash<QVariantList> values = StrHash<QVariantList>());
QString getAlias(const QString& name, QSet<QString>& usedAliases);
QStringList valuesToConditionList(const StrHash<QVariantList>& values);
QString valuesToConditionStr(const StrHash<QVariantList>& values);
QString toResultColumnString(const SelectResolver::Column& column);
QString toFullObjectName(const QString& database, const QString& object);
QStringList toValueSets(const QStringList& columns, const StrHash<QVariantList> values);
};
#endif // QUERYGENERATOR_H
|