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
|
#ifndef SQLITEINSERT_H
#define SQLITEINSERT_H
#include "sqlitequery.h"
#include "sqliteconflictalgo.h"
#include "sqliteselect.h"
#include "sqlitequerywithaliasedtable.h"
#include <QString>
#include <QList>
class SqliteExpr;
class SqliteWith;
class SqliteUpsert;
class API_EXPORT SqliteInsert : public SqliteQuery, SqliteQueryWithAliasedTable
{
Q_OBJECT
public:
SqliteInsert();
SqliteInsert(const SqliteInsert& other);
SqliteInsert(bool replace, SqliteConflictAlgo onConflict, const QString& name1,
const QString& name2, const QString& alias, const QList<QString>& columns,
const QList<SqliteExpr*>& row, SqliteWith* with,
const QList<SqliteResultColumn*>& returning);
SqliteInsert(bool replace, SqliteConflictAlgo onConflict, const QString& name1,
const QString& name2, const QString& alias, const QList<QString>& columns,
SqliteSelect* select, SqliteWith* with,
SqliteUpsert* upsert, const QList<SqliteResultColumn*>& returning);
SqliteInsert(bool replace, SqliteConflictAlgo onConflict, const QString& name1,
const QString& name2, const QString& alias, const QList<QString>& columns,
SqliteWith* with, const QList<SqliteResultColumn*>& returning);
~SqliteInsert();
SqliteStatement* clone();
QString getTable() const;
QString getDatabase() const;
QString getTableAlias() const;
protected:
QStringList getColumnsInStatement();
QStringList getTablesInStatement();
QStringList getDatabasesInStatement();
TokenList getColumnTokensInStatement();
TokenList getTableTokensInStatement();
TokenList getDatabaseTokensInStatement();
QList<FullObject> getFullObjectsInStatement();
TokenList rebuildTokensFromContents();
private:
void init(const QString& name1, const QString& name2, const QString& alias, bool replace,
SqliteConflictAlgo onConflict, const QList<SqliteResultColumn*>& returning);
public:
bool replaceKw = false;
bool defaultValuesKw = false;
SqliteConflictAlgo onConflict = SqliteConflictAlgo::null;
QString database = QString();
QString table = QString();
QStringList columnNames;
QList<SqliteExpr*> values;
SqliteSelect* select = nullptr;
SqliteWith* with = nullptr;
SqliteUpsert* upsert = nullptr;
QList<SqliteResultColumn*> returning;
QString tableAlias = QString();
};
typedef QSharedPointer<SqliteInsert> SqliteInsertPtr;
#endif // SQLITEINSERT_H
|