15#include <QSharedPointer>
17#include <qaglobalutils.h>
33 QString queryString =
"SELECT " + map.join(
",") +
" FROM %0 ";
34 queryString = queryString.arg(
table());
37 auto [conditionQueryString, conditionBindingMap] =
condition();
39 if (conditionQueryString.size()) {
41 queryString +=
" WHERE " + conditionQueryString;
42 if (!q.prepare(queryString)) {
46 for (
auto it = conditionBindingMap.begin(); it != conditionBindingMap.end(); ++it) {
47 q.bindValue(it.key(), it.value());
54 if (!q.prepare(queryString)) {
66 QuasarAppUtils::Params::log(
"The variantMap method return an empty map.",
67 QuasarAppUtils::Error);
72 QString queryString = (replace)?
73 "REPLACE INTO %0(%1) VALUES (%2) " :
74 "INSERT INTO %0(%1) VALUES (%2) ";
77 queryString = queryString.arg(
table());
78 QString tableInsertHeader =
"";
79 QString tableInsertValues =
"";
81 for (
auto it = map.begin(); it != map.end(); ++it) {
91 tableInsertHeader += it.key();
92 tableInsertValues +=
":" + it.key();
93 if (std::next(it, 1) != map.end()) {
94 tableInsertHeader +=
", ";
95 tableInsertValues +=
", ";
100 queryString = queryString.arg(tableInsertHeader);
101 queryString = queryString.arg(tableInsertValues);
103 if (q.prepare(queryString)) {
105 for (
auto it = map.begin(); it != map.end(); ++it) {
114 q.bindValue(
":" + it.key(), it.value().value);
128 QuasarAppUtils::Params::log(
"The variantMap method return an empty map.",
129 QuasarAppUtils::Error);
134 auto [conditionQueryString, conditionBindingMap] =
condition();
136 if (conditionQueryString.isEmpty()) {
137 QuasarAppUtils::Params::log(
"The object soue not have condition for update object.",
138 QuasarAppUtils::Error);
142 QString queryString =
"UPDATE %0 SET %1 WHERE " + conditionQueryString;
144 queryString = queryString.arg(
table());
145 QString tableUpdateValues =
"";
147 for (
auto it = map.begin(); it != map.end(); ++it) {
152 if (tableUpdateValues.size()) {
153 tableUpdateValues +=
", ";
156 tableUpdateValues += QString(
"%0= :%0").arg(it.key());
160 if (tableUpdateValues.isEmpty()) {
161 QuasarAppUtils::Params::log(
"Fail to generate condition for object: " +
toString() +
162 ". The object do not have valid update fields.",
163 QuasarAppUtils::Error);
167 queryString = queryString.arg(tableUpdateValues);
169 if (q.prepare(queryString)) {
171 for (
auto it = map.begin(); it != map.end(); ++it) {
176 q.bindValue(
":" + it.key(), it.value().value);
179 for (
auto it = conditionBindingMap.begin(); it != conditionBindingMap.end(); ++it) {
182 QuasarAppUtils::Params::log(QString(
"Bad object configuration: "
183 "The %0 field using in the condition and has MemberType::Update configuration."
184 " All condition fields should not use the MemberType::Update. \n %1").
186 QuasarAppUtils::Warning);
189 q.bindValue(it.key(), it.value());
216 if (!primaryVal.isNull()) {
217 return {QString(
"%0 = :%0").arg(
primaryKey()),
218 {{QString(
":%0").arg(
primaryKey()), {primaryVal}}}};
222 QuasarAppUtils::Params::log(
"Fail to generate condition for object: " +
toString() +
223 ". Object do not have valid unique fields or valid database address.",
224 QuasarAppUtils::Error);
252 QuasarAppUtils::Params::log(
"This object not support stream operator."
253 " Please Override the fromStream method for this object. " +
toString(),
254 QuasarAppUtils::Warning);
261 QuasarAppUtils::Params::log(
"This object not support stream operator."
262 " Please Override the toStream method for this object. " +
toString(),
263 QuasarAppUtils::Warning);
269 QString queryString =
"DELETE FROM %0 ";
270 queryString = queryString.arg(
table());
272 auto [conditionQueryString, conditionBindingMap] =
condition();
274 if (conditionQueryString.size()) {
276 queryString +=
" WHERE " + conditionQueryString;
277 if (!q.prepare(queryString)) {
281 for (
auto it = conditionBindingMap.begin(); it != conditionBindingMap.end(); ++it) {
282 q.bindValue(it.key(), it.value());
288 if (!q.prepare(queryString)) {
311 return table().size();
The DbAddress class use to work with database addresses. Database Address it is structure with 2 valu...
virtual bool isValid() const
isValid This method check current object to valid.
QString toString() const override
toString - Return a string implementation for this object.
DbAddress dbAddress() const
dbAddress This method return address of the database object. IF the object is not valid then this met...
bool isHaveAPrimaryKey() const
isHaveAPrimaryKey This method return true if this object has a primary key. If you want to cache this...
virtual PrepareResult prepareRemoveQuery(QSqlQuery &q) const
prepareRemoveQuery This method should be prepare a query for remove this object from a database....
virtual std::pair< QString, QMap< QString, QVariant > > condition() const
condition This method must to return a condition of the WHERE block of the sql query....
QDataStream & toStream(QDataStream &stream) const override
fromStream This method should be write all members of the current object to the stream object.
bool isInsertPrimaryKey() const
isInsertPrimaryKey This method check primaryKeys type. If the primary key have a type MemberType::Ins...
virtual DBVariantMap variantMap() const
variantMap This method should be create a DBVariantMap implementation of this database object.
QDataStream & fromStream(QDataStream &stream) override
fromStream This method should be read all bytes from the stream object and full the current object.
virtual void clear()
clear This method clear all data of database object. Override This method for remove or reset your ow...
virtual QString primaryKey() const
primaryKey This method must be return the name of primary key of this object table....
QString toString() const override
virtual PrepareResult prepareSelectQuery(QSqlQuery &q) const
prepareSelectQuery This method should be prepare a query for selected data. Override this method for ...
virtual PrepareResult prepareUpdateQuery(QSqlQuery &q) const
prepareUpdateQuery this method should be prepare a insert data query.
virtual PrepareResult prepareInsertQuery(QSqlQuery &q, bool replace) const
prepareInsertQuery This method should be prepare a query for insert object into database....
virtual bool isCached() const
isCached This method sholud be return status of object. If this method return true then this object c...
virtual bool isBundle() const
isBundle This method definef determines whether the object will be abstract (composite objects) or si...
bool isValid() const override
isValid This method check current object to valid.
virtual QString table() const =0
table This method should be return name of the database table that should be contains objects with th...
virtual QVariant primaryValue() const
primaryValue This method is wraper of DBAddress::id. If This object do not contains a id value then r...
PrepareResult
The PrepareResult enum is result of work prepare sql query of dbobjects.
@ Success
prepare finished successful.
QMap< QString, DBVariant > DBVariantMap
DBVariantMap this is Map with key, and value with data type.
MemberType
The MemberType enum. This enum contains types of members DBObjects classes. for more information see ...
@ Update
The Field With This type can be updated but not inserted.
@ PrimaryKey
The primary key field without autoincrement.
@ Autoincement
The field with this atribute automaticaly incemented into database, and will not to added into insert...
@ Insert
The Field With This type can be inserted but not updated.
The QH namespace - QuasarApp Heart namespace. This namespace contains all classes of the Heart librar...