qsql_sqlite and qsql_sqlite2: don't hold driver data in result
Change-Id: Ia4f6adc6daaea97ac06246e9d01c6561de1227ea Reviewed-by: Friedemann Kleint <Friedemann.Kleint@theqtcompany.com>
This commit is contained in:
parent
a5cd081879
commit
371c2e4786
@ -150,8 +150,6 @@ public:
|
|||||||
void initColumns(bool emptyResultset);
|
void initColumns(bool emptyResultset);
|
||||||
void finalize();
|
void finalize();
|
||||||
|
|
||||||
sqlite3 *access;
|
|
||||||
|
|
||||||
sqlite3_stmt *stmt;
|
sqlite3_stmt *stmt;
|
||||||
|
|
||||||
bool skippedStatus; // the status of the fetchNext() that's skipped
|
bool skippedStatus; // the status of the fetchNext() that's skipped
|
||||||
@ -326,7 +324,7 @@ bool QSQLiteResultPrivate::fetchNext(QSqlCachedResult::ValueCache &values, int i
|
|||||||
// SQLITE_ERROR is a generic error code and we must call sqlite3_reset()
|
// SQLITE_ERROR is a generic error code and we must call sqlite3_reset()
|
||||||
// to get the specific error message.
|
// to get the specific error message.
|
||||||
res = sqlite3_reset(stmt);
|
res = sqlite3_reset(stmt);
|
||||||
q->setLastError(qMakeError(access, QCoreApplication::translate("QSQLiteResult",
|
q->setLastError(qMakeError(drv_d_func()->access, QCoreApplication::translate("QSQLiteResult",
|
||||||
"Unable to fetch row"), QSqlError::ConnectionError, res));
|
"Unable to fetch row"), QSqlError::ConnectionError, res));
|
||||||
q->setAt(QSql::AfterLastRow);
|
q->setAt(QSql::AfterLastRow);
|
||||||
return false;
|
return false;
|
||||||
@ -334,7 +332,7 @@ bool QSQLiteResultPrivate::fetchNext(QSqlCachedResult::ValueCache &values, int i
|
|||||||
case SQLITE_BUSY:
|
case SQLITE_BUSY:
|
||||||
default:
|
default:
|
||||||
// something wrong, don't get col info, but still return false
|
// something wrong, don't get col info, but still return false
|
||||||
q->setLastError(qMakeError(access, QCoreApplication::translate("QSQLiteResult",
|
q->setLastError(qMakeError(drv_d_func()->access, QCoreApplication::translate("QSQLiteResult",
|
||||||
"Unable to fetch row"), QSqlError::ConnectionError, res));
|
"Unable to fetch row"), QSqlError::ConnectionError, res));
|
||||||
sqlite3_reset(stmt);
|
sqlite3_reset(stmt);
|
||||||
q->setAt(QSql::AfterLastRow);
|
q->setAt(QSql::AfterLastRow);
|
||||||
@ -347,7 +345,6 @@ QSQLiteResult::QSQLiteResult(const QSQLiteDriver* db)
|
|||||||
: QSqlCachedResult(*new QSQLiteResultPrivate(this, db))
|
: QSqlCachedResult(*new QSQLiteResultPrivate(this, db))
|
||||||
{
|
{
|
||||||
Q_D(QSQLiteResult);
|
Q_D(QSQLiteResult);
|
||||||
d->access = d->drv_d_func()->access;
|
|
||||||
const_cast<QSQLiteDriverPrivate*>(d->drv_d_func())->results.append(this);
|
const_cast<QSQLiteDriverPrivate*>(d->drv_d_func())->results.append(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -383,7 +380,7 @@ bool QSQLiteResult::prepare(const QString &query)
|
|||||||
const void *pzTail = NULL;
|
const void *pzTail = NULL;
|
||||||
|
|
||||||
#if (SQLITE_VERSION_NUMBER >= 3003011)
|
#if (SQLITE_VERSION_NUMBER >= 3003011)
|
||||||
int res = sqlite3_prepare16_v2(d->access, query.constData(), (query.size() + 1) * sizeof(QChar),
|
int res = sqlite3_prepare16_v2(d->drv_d_func()->access, query.constData(), (query.size() + 1) * sizeof(QChar),
|
||||||
&d->stmt, &pzTail);
|
&d->stmt, &pzTail);
|
||||||
#else
|
#else
|
||||||
int res = sqlite3_prepare16(d->access, query.constData(), (query.size() + 1) * sizeof(QChar),
|
int res = sqlite3_prepare16(d->access, query.constData(), (query.size() + 1) * sizeof(QChar),
|
||||||
@ -391,12 +388,12 @@ bool QSQLiteResult::prepare(const QString &query)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (res != SQLITE_OK) {
|
if (res != SQLITE_OK) {
|
||||||
setLastError(qMakeError(d->access, QCoreApplication::translate("QSQLiteResult",
|
setLastError(qMakeError(d->drv_d_func()->access, QCoreApplication::translate("QSQLiteResult",
|
||||||
"Unable to execute statement"), QSqlError::StatementError, res));
|
"Unable to execute statement"), QSqlError::StatementError, res));
|
||||||
d->finalize();
|
d->finalize();
|
||||||
return false;
|
return false;
|
||||||
} else if (pzTail && !QString(reinterpret_cast<const QChar *>(pzTail)).trimmed().isEmpty()) {
|
} else if (pzTail && !QString(reinterpret_cast<const QChar *>(pzTail)).trimmed().isEmpty()) {
|
||||||
setLastError(qMakeError(d->access, QCoreApplication::translate("QSQLiteResult",
|
setLastError(qMakeError(d->drv_d_func()->access, QCoreApplication::translate("QSQLiteResult",
|
||||||
"Unable to execute multiple statements at a time"), QSqlError::StatementError, SQLITE_MISUSE));
|
"Unable to execute multiple statements at a time"), QSqlError::StatementError, SQLITE_MISUSE));
|
||||||
d->finalize();
|
d->finalize();
|
||||||
return false;
|
return false;
|
||||||
@ -417,7 +414,7 @@ bool QSQLiteResult::exec()
|
|||||||
|
|
||||||
int res = sqlite3_reset(d->stmt);
|
int res = sqlite3_reset(d->stmt);
|
||||||
if (res != SQLITE_OK) {
|
if (res != SQLITE_OK) {
|
||||||
setLastError(qMakeError(d->access, QCoreApplication::translate("QSQLiteResult",
|
setLastError(qMakeError(d->drv_d_func()->access, QCoreApplication::translate("QSQLiteResult",
|
||||||
"Unable to reset statement"), QSqlError::StatementError, res));
|
"Unable to reset statement"), QSqlError::StatementError, res));
|
||||||
d->finalize();
|
d->finalize();
|
||||||
return false;
|
return false;
|
||||||
@ -477,7 +474,7 @@ bool QSQLiteResult::exec()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (res != SQLITE_OK) {
|
if (res != SQLITE_OK) {
|
||||||
setLastError(qMakeError(d->access, QCoreApplication::translate("QSQLiteResult",
|
setLastError(qMakeError(d->drv_d_func()->access, QCoreApplication::translate("QSQLiteResult",
|
||||||
"Unable to bind parameters"), QSqlError::StatementError, res));
|
"Unable to bind parameters"), QSqlError::StatementError, res));
|
||||||
d->finalize();
|
d->finalize();
|
||||||
return false;
|
return false;
|
||||||
@ -513,14 +510,14 @@ int QSQLiteResult::size()
|
|||||||
int QSQLiteResult::numRowsAffected()
|
int QSQLiteResult::numRowsAffected()
|
||||||
{
|
{
|
||||||
Q_D(const QSQLiteResult);
|
Q_D(const QSQLiteResult);
|
||||||
return sqlite3_changes(d->access);
|
return sqlite3_changes(d->drv_d_func()->access);
|
||||||
}
|
}
|
||||||
|
|
||||||
QVariant QSQLiteResult::lastInsertId() const
|
QVariant QSQLiteResult::lastInsertId() const
|
||||||
{
|
{
|
||||||
Q_D(const QSQLiteResult);
|
Q_D(const QSQLiteResult);
|
||||||
if (isActive()) {
|
if (isActive()) {
|
||||||
qint64 id = sqlite3_last_insert_rowid(d->access);
|
qint64 id = sqlite3_last_insert_rowid(d->drv_d_func()->access);
|
||||||
if (id)
|
if (id)
|
||||||
return id;
|
return id;
|
||||||
}
|
}
|
||||||
|
@ -127,8 +127,6 @@ public:
|
|||||||
void init(const char **cnames, int numCols);
|
void init(const char **cnames, int numCols);
|
||||||
void finalize();
|
void finalize();
|
||||||
|
|
||||||
sqlite *access;
|
|
||||||
|
|
||||||
// and we have too keep our own struct for the data (sqlite works via
|
// and we have too keep our own struct for the data (sqlite works via
|
||||||
// callback.
|
// callback.
|
||||||
const char *currentTail;
|
const char *currentTail;
|
||||||
@ -136,7 +134,6 @@ public:
|
|||||||
|
|
||||||
bool skippedStatus; // the status of the fetchNext() that's skipped
|
bool skippedStatus; // the status of the fetchNext() that's skipped
|
||||||
bool skipRow; // skip the next fetchNext()?
|
bool skipRow; // skip the next fetchNext()?
|
||||||
bool utf8;
|
|
||||||
QSqlRecord rInf;
|
QSqlRecord rInf;
|
||||||
QVector<QVariant> firstRow;
|
QVector<QVariant> firstRow;
|
||||||
};
|
};
|
||||||
@ -148,8 +145,7 @@ QSQLite2ResultPrivate::QSQLite2ResultPrivate(QSQLite2Result *q, const QSQLite2Dr
|
|||||||
currentTail(0),
|
currentTail(0),
|
||||||
currentMachine(0),
|
currentMachine(0),
|
||||||
skippedStatus(false),
|
skippedStatus(false),
|
||||||
skipRow(false),
|
skipRow(false)
|
||||||
utf8(false)
|
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -261,7 +257,7 @@ bool QSQLite2ResultPrivate::fetchNext(QSqlCachedResult::ValueCache &values, int
|
|||||||
if (idx < 0 && !initialFetch)
|
if (idx < 0 && !initialFetch)
|
||||||
return true;
|
return true;
|
||||||
for (i = 0; i < colNum; ++i)
|
for (i = 0; i < colNum; ++i)
|
||||||
values[i + idx] = utf8 ? QString::fromUtf8(fvals[i]) : QString::fromLatin1(fvals[i]);
|
values[i + idx] = drv_d_func()->utf8 ? QString::fromUtf8(fvals[i]) : QString::fromLatin1(fvals[i]);
|
||||||
return true;
|
return true;
|
||||||
case SQLITE_DONE:
|
case SQLITE_DONE:
|
||||||
if (rInf.isEmpty())
|
if (rInf.isEmpty())
|
||||||
@ -283,9 +279,6 @@ bool QSQLite2ResultPrivate::fetchNext(QSqlCachedResult::ValueCache &values, int
|
|||||||
QSQLite2Result::QSQLite2Result(const QSQLite2Driver* db)
|
QSQLite2Result::QSQLite2Result(const QSQLite2Driver* db)
|
||||||
: QSqlCachedResult(*new QSQLite2ResultPrivate(this, db))
|
: QSqlCachedResult(*new QSQLite2ResultPrivate(this, db))
|
||||||
{
|
{
|
||||||
Q_D(QSQLite2Result);
|
|
||||||
d->access = d->drv_d_func()->access;
|
|
||||||
d->utf8 = d->drv_d_func()->utf8;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
QSQLite2Result::~QSQLite2Result()
|
QSQLite2Result::~QSQLite2Result()
|
||||||
@ -316,8 +309,8 @@ bool QSQLite2Result::reset (const QString& query)
|
|||||||
// Um, ok. callback based so.... pass private static function for this.
|
// Um, ok. callback based so.... pass private static function for this.
|
||||||
setSelect(false);
|
setSelect(false);
|
||||||
char *err = 0;
|
char *err = 0;
|
||||||
int res = sqlite_compile(d->access,
|
int res = sqlite_compile(d->drv_d_func()->access,
|
||||||
d->utf8 ? query.toUtf8().constData()
|
d->drv_d_func()->utf8 ? query.toUtf8().constData()
|
||||||
: query.toLatin1().constData(),
|
: query.toLatin1().constData(),
|
||||||
&(d->currentTail),
|
&(d->currentTail),
|
||||||
&(d->currentMachine),
|
&(d->currentMachine),
|
||||||
@ -359,8 +352,8 @@ int QSQLite2Result::size()
|
|||||||
|
|
||||||
int QSQLite2Result::numRowsAffected()
|
int QSQLite2Result::numRowsAffected()
|
||||||
{
|
{
|
||||||
Q_D(const QSQLite2Result);
|
Q_D(QSQLite2Result);
|
||||||
return sqlite_changes(d->access);
|
return sqlite_changes(d->drv_d_func()->access);
|
||||||
}
|
}
|
||||||
|
|
||||||
QSqlRecord QSQLite2Result::record() const
|
QSqlRecord QSQLite2Result::record() const
|
||||||
|
Loading…
Reference in New Issue
Block a user