提问者:小点点

如何编写准备好的更新查询?


我一直在尝试编写一个更新函数,该函数包含要更新的用户(usr),然后转换为要更新的字段的标志和新值。 这是函数,

bool DBManager::updateDB(User* usr, int flag, QVariant& value)
{
    QSqlQuery query;
    bool status = false;
    QString temp_value = "";
    QList<QString> fieldlist = {"First_Name", "Last_Name", "Email", "Username", "Password"};
    QString field = fieldlist.at(flag);

    if (field == "First_Name") {
        usr->setFirstName(value.toString());
        temp_value = usr->getFirstName();
    } else if (field == "Last_Name") {
        usr->setLastName(value.toString());
        temp_value = usr->getLastName();
    } else {
        qDebug() << "invalid option";
    }

    query.prepare("UPADATE Users SET :field = :newValue WHERE Username = :Username");
    query.bindValue(":field",field);
    query.bindValue(":newValue",temp_value);
    query.bindValue(":Username",usr->getUserName());
    qDebug() << query.boundValues();
    if (m_db.isOpen()){
        if (query.exec()){
            status = true;
            qDebug() << "DATABASE:: Record update successful";
        } else {
            qDebug() << "DATABASE:: Record update unsuccessful - " << query.lastError();
        }
    } else {
        qDebug() << "DATABASE:: not open ";
    }

    return status;
}

当我运行代码时,我得到一个错误。 以下是输出:

QMap((":Username", QVariant(QString, "zielinkin1"))(":field", QVariant(QString, "Last_Name"))(":newValue", QVariant(QString, "Thibos")))

DATABASE:: Record update unsuccessful -  QSqlError("", "Parameter count mismatch", "") User not updated DATABASE:: database closed

怎么解决这个问题?


共1个答案

匿名用户

第一个问题

不难猜测,值绑定只对值起作用,而不对字段名起作用。

有关更多信息,请阅读“插入,更新和删除记录”。

第二个问题

@JimCastro发现:

您的查询中有一个错误。 upadate应为update

使用字符串串联来形成准备好的查询。

>

  • 而不是

    query.prepare("UPDATE Users SET :field = :newValue WHERE Username = :Username");
    

    query.prepare("UPDATE Users SET " + field + " = :newValue WHERE Username = :Username");
    

    删除或注释此行

    query.bindValue(":field",field);