sptk2 logo
SPTK Home Page
QueryBuilder.h
1/*
2╔══════════════════════════════════════════════════════════════════════════════╗
3║ SIMPLY POWERFUL TOOLKIT (SPTK) ║
4╟──────────────────────────────────────────────────────────────────────────────╢
5║ copyright © 1999-2022 Alexey Parshin. All rights reserved. ║
6║ email alexeyp@gmail.com ║
7╚══════════════════════════════════════════════════════════════════════════════╝
8┌──────────────────────────────────────────────────────────────────────────────┐
9│ This library is free software; you can redistribute it and/or modify it │
10│ under the terms of the GNU Library General Public License as published by │
11│ the Free Software Foundation; either version 2 of the License, or (at your │
12│ option) any later version. │
13│ │
14│ This library is distributed in the hope that it will be useful, but │
15│ WITHOUT ANY WARRANTY; without even the implied warranty of │
16│ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library │
17│ General Public License for more details. │
18│ │
19│ You should have received a copy of the GNU Library General Public License │
20│ along with this library; if not, write to the Free Software Foundation, │
21│ Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. │
22│ │
23│ Please report all bugs and problems to alexeyp@gmail.com. │
24└──────────────────────────────────────────────────────────────────────────────┘
25*/
26
27#pragma once
28
29#include <memory>
30#include <sptk5/Strings.h>
31
32namespace sptk {
33
35{
36public:
37 class Join
38 {
39 public:
40 Join(const String& tableAlias, const Strings& columns, const String& join);
41
42 String tableAlias;
43 Strings columns;
44 String joinDefinition;
45 };
46
47 QueryBuilder(const String& tableName, const String& pkColumn, const Strings& columns = {},
48 const std::vector<Join>& joins = {});
49
50 virtual ~QueryBuilder() = default;
51
52 virtual String selectSQL(const Strings& filter, const Strings& columns, bool pretty) const;
53
54 virtual String insertSQL(const Strings& columns, bool pretty) const;
55
56 virtual String updateSQL(const Strings& filter, const Strings& columns, bool pretty) const;
57
58 virtual String deleteSQL(const Strings& filter, bool pretty) const;
59
60 String tableName() const;
61
62 String pkColumnName() const;
63
64private:
65 String m_tableName;
66 String m_pkColumn;
67 Strings m_columns;
68 std::vector<Join> m_joins;
69
70 Strings makeSelectColumns(const Strings& columns) const;
71
72 void removeUnNeededColumns(const Join& join, const String& tableAlias);
73};
74
75} // namespace sptk
Definition: QueryBuilder.h:38
Definition: QueryBuilder.h:35
Definition: String.h:49
Definition: Strings.h:52

Fri Oct 14 2022 09:58:31: SPTK 5.4.1