int QuerySocket::getIndexOfLastQuery(const QStringList &list) { if( list.count() == 0 ) return -1; QString str = lastQuery(); if( str.isNull() || str.isEmpty() ) return -1; int pos = str.indexOf( "(", 0 ); if( pos < 0 ) return -1; str = str.left( pos ); int i = 0; bool ok = false; for( i = 0; i < list.count(); i++ ) { if( list.at(i) == str ) { ok = true; break; } } if( !ok ) return -1; return i; }
void SqlQuery::exec() { bool success = QSqlQuery::exec(); if (!success) { THROW(DatabaseException, lastError().text() + "\nQuery: " + lastQuery()); } }
bool TSqlQuery::exec() { bool ret = QSqlQuery::exec(); QString q = executedQuery(); QString str = (ret) ? q : (QLatin1String("(Query failed) ") + (q.isEmpty() ? lastQuery() : q)); tQueryLog("%s", qPrintable(str)); return ret; }
/*! Executes the query, returning true if successful; otherwise returns false. \sa prepare() */ bool QSqlResult::exec() { Q_D(QSqlResult); bool ret; // fake preparation - just replace the placeholders.. QString query = lastQuery(); if (d->binds == NamedBinding) { int i; QVariant val; QString holder; for (i = d->holders.count() - 1; i >= 0; --i) { holder = d->holders.at(i).holderName; val = d->values.value(d->indexes.value(holder).value(0,-1)); QSqlField f(QLatin1String(""), val.type()); f.setValue(val); query = query.replace(d->holders.at(i).holderPos, holder.length(), driver()->formatValue(f)); } } else { QString val; int i = 0; int idx = 0; for (idx = 0; idx < d->values.count(); ++idx) { i = query.indexOf(QLatin1Char('?'), i); if (i == -1) continue; QVariant var = d->values.value(idx); QSqlField f(QLatin1String(""), var.type()); if (var.isNull()) f.clear(); else f.setValue(var); val = driver()->formatValue(f); query = query.replace(i, 1, driver()->formatValue(f)); i += val.length(); } } // have to retain the original query with placeholders QString orig = lastQuery(); ret = reset(query); d->executedQuery = query; setQuery(orig); d->resetBindCount(); return ret; }
QVariant ISqlQuery::value ( int index ) const { QVariant v = QSqlQuery::value(index); if (!v.isValid()) { qWarning() << "Got an invalid value while trying to access index" << index << "of query" << lastQuery(); } return v; }
bool MSqlQuery::exec() { // Database connection down. Try to restart it, give up if it's still // down if (!m_db) { // Database structure's been deleted return false; } if (!m_db->isOpen() && !m_db->Reconnect()) { LOG(VB_GENERAL, LOG_INFO, "MySQL server disconnected"); return false; } bool result = QSqlQuery::exec(); // if the query failed with "MySQL server has gone away" // Close and reopen the database connection and retry the query if it // connects again if (!result && QSqlQuery::lastError().number() == 2006 && m_db->Reconnect()) result = QSqlQuery::exec(); if (VERBOSE_LEVEL_CHECK(VB_DATABASE) && logLevel <= LOG_DEBUG) { QString str = lastQuery(); // Database logging will cause an infinite loop here if not filtered // out if (!str.startsWith("INSERT INTO logging ")) { // Sadly, neither executedQuery() nor lastQuery() display // the values in bound queries against a MySQL5 database. // So, replace the named placeholders with their values. QMapIterator<QString, QVariant> b = boundValues(); while (b.hasNext()) { b.next(); str.replace(b.key(), '\'' + b.value().toString() + '\''); } LOG(VB_DATABASE, LOG_DEBUG, QString("MSqlQuery::exec(%1) %2%3") .arg(m_db->MSqlDatabase::GetConnectionName()).arg(str) .arg(isSelect() ? QString(" <<<< Returns %1 row(s)") .arg(size()) : QString())); } } return result; }
bool MSqlQuery::exec() { if (!m_db) { // Database structure's been deleted return false; } if (m_last_prepared_query.isEmpty()) { LOG(VB_GENERAL, LOG_ERR, "MSqlQuery::exec(void) called without a prepared query."); return false; } #if DEBUG_RECONNECT if (random() < RAND_MAX / 50) { LOG(VB_GENERAL, LOG_INFO, "MSqlQuery disconnecting DB to test reconnection logic"); m_db->m_db.close(); } #endif // Database connection down. Try to restart it, give up if it's still // down if (!m_db->isOpen() && !Reconnect()) { LOG(VB_GENERAL, LOG_INFO, "MySQL server disconnected"); return false; } QElapsedTimer timer; timer.start(); bool result = QSqlQuery::exec(); qint64 elapsed = timer.elapsed(); // if the query failed with "MySQL server has gone away" // Close and reopen the database connection and retry the query if it // connects again if (!result && QSqlQuery::lastError().number() == 2006 && Reconnect()) result = QSqlQuery::exec(); if (!result) { QString err = MythDB::GetError("MSqlQuery", *this); MSqlBindings tmp = QSqlQuery::boundValues(); bool has_null_strings = false; for (MSqlBindings::iterator it = tmp.begin(); it != tmp.end(); ++it) { if (it->type() != QVariant::String) continue; if (it->isNull() || it->toString().isNull()) { has_null_strings = true; *it = QVariant(QString("")); } } if (has_null_strings) { bindValues(tmp); timer.restart(); result = QSqlQuery::exec(); elapsed = timer.elapsed(); } if (result) { LOG(VB_GENERAL, LOG_ERR, QString("Original query failed, but resend with empty " "strings in place of NULL strings worked. ") + "\n" + err); } } if (VERBOSE_LEVEL_CHECK(VB_DATABASE, LOG_INFO)) { QString str = lastQuery(); // Database logging will cause an infinite loop here if not filtered // out if (!str.startsWith("INSERT INTO logging ")) { // Sadly, neither executedQuery() nor lastQuery() display // the values in bound queries against a MySQL5 database. // So, replace the named placeholders with their values. QMapIterator<QString, QVariant> b = boundValues(); while (b.hasNext()) { b.next(); str.replace(b.key(), '\'' + b.value().toString() + '\''); } LOG(VB_DATABASE, LOG_INFO, QString("MSqlQuery::exec(%1) %2%3%4") .arg(m_db->MSqlDatabase::GetConnectionName()).arg(str) .arg(QString(" <<<< Took %1ms").arg(QString::number(elapsed))) .arg(isSelect() ? QString(", Returned %1 row(s)") .arg(size()) : QString())); } } return result; }
// this is called arse because both check and verify wouldn't compile! bool arse( bool success ) { if (!success) qWarning() << lastError().text() << "in query:\n" << lastQuery(); return success; }
// this is called arse because both check and verify wouldn't compile! bool arse( bool success ) { if (!success) LOGL( 2, lastError().text() << " in query:\n" << lastQuery() ); return success; }