21 const QVariant& value,
22 const QString &primaryKey) {
23 _primaryValue = address.
id();
24 _table = address.
table();
31 return create<SetSingleValue>(
dbAddress(), _field, _value);
35 QString queryString =
"UPDATE %0 SET %1=:%1 WHERE %2=:%2";
39 if (!q.prepare(queryString)) {
41 qCritical() <<
"Failed to prepare query: " + q.lastError().text();
45 q.bindValue(
":" + _field, _value);
46 q.bindValue(
":" + _primaryKey, _primaryValue);
53 QString queryString = (replace)?
54 "REPLACE INTO %0 (%1, %2) VALUES (:%1, :%2)":
55 "INSERT INTO %0 (%1, %2) VALUES (:%1, :%2)";
59 if (!q.prepare(queryString)) {
61 qCritical() <<
"Failed to prepare query: " + q.lastError().text();
65 q.bindValue(
":" + _primaryKey, _primaryValue);
66 q.bindValue(
":" + _field, _value);
The DbAddress class use to work with database addresses. Database Address it is structure with 2 valu...
const QString & table() const
table This method return table name.
const QVariant & id() const
id This method return id of object in table.
The DBObject class- main class for work with data base.
DbAddress dbAddress() const
dbAddress This method return address of the database object. IF the object is not valid then this met...
QVariant primaryValue() const override
primaryValue This method is wraper of DBAddress::id. If This object do not contains a id value then r...
QString table() const override
table This method should be return name of the database table that should be contains objects with th...
DBObject * createDBObject() const override
createDBObject This method should be create a object with the some type as the object called this met...
bool isCached() const override
isCached This method sholud be return status of object. If this method return true then this object c...
SetSingleValue(const DbAddress &address, const QString &field, const QVariant &value, const QString &primaryKey="id")
SetSingleValue This is default constructor of the update query generator.
bool fromSqlRecord(const QSqlRecord &q) override
fromSqlRecord This method should be initialize this object from the executed sqlRecord....
QString primaryKey() const override
primaryKey This method must be return the name of primary key of this object table....
PrepareResult prepareUpdateQuery(QSqlQuery &q) const override
prepareUpdateQuery this method should be prepare a insert data query.
PrepareResult prepareInsertQuery(QSqlQuery &q, bool replace) const override
prepareInsertQuery This method should be prepare a query for insert object into database....
PrepareResult
The PrepareResult enum is result of work prepare sql query of dbobjects.
@ Success
prepare finished successful.
The QH namespace - QuasarApp Heart namespace. This namespace contains all classes of the Heart librar...