c++ - Qt & Sqlite 向数据库中插入数据

标签 c++ qt sqlite qt5 qtsql

我正在做 Qt 应用程序。我正在尝试将数据保存在数据库中。我遇到了问题,因为我已经连接到 sqlite3,但是当我想要插入数据时,QT 说 QSqlQuery::prepare: 数据库未打开。

void DodajKontakt::on_btn_add_clicked()
{

    QSqlDatabase db_kon = QSqlDatabase::addDatabase("QSQLITE");
    db_kon.setDatabaseName("C:/Users/Lukasz/Desktop/qt master/organizator/baza_kontakty.db");

    QSqlQuery query;
    query.prepare( "CREATE TABLE kontakty(ids INTEGER PRIMARY KEY, name TEXT, surname TEXT, company TEXT, email TEXT, phone TEXT");

    if(!db_kon.open())
    {
        qDebug() << "error:" << db_kon.lastError().text();
    }
    else
        qDebug() << "Succsess";

    if(ui->lineEdit_name->text().isEmpty() && ui->lineEdit_surname->text().isEmpty()
            && ui->lineEdit_email->text().isEmpty() && ui->lineEdit_phone->text().isEmpty()
            && ui->lineEdit_company->text().isEmpty())
    {
        QMessageBox::critical(this, tr("Error"), tr("Uzupełnij wszystkie pola!"));

    }
    else
    {
        QString name, surname, company, email, phone;
        name = ui ->lineEdit_name->text();
        surname = ui ->lineEdit_surname->text();
        company = ui ->lineEdit_company->text();
        email = ui ->lineEdit_email->text();
        phone = ui ->lineEdit_phone->text();



        query.prepare("INSERT INTO kontakty(name,surname,company.email.phone) VALUES('"+name+"','"+surname+"','"+company+"','"+email+"','"+phone+"')");
        if(query.exec())
            QMessageBox::information(this, tr("Sukces"),tr("Dodano nowy kontakt"));
        else
            QMessageBox::information(this, tr("Error"),tr("Nie udalo sie dodac nowego kontaktu"));
    }
}

是结果。

QSqlQuery::prepare: database not open
Succsess

有人可以帮助我吗?

最佳答案

您的主要错误是您试图在打开数据库之前创建表,这就是您收到该错误的原因。

另一个重复的错误是,即使发生问题,您的逻辑仍然要插入数据,您应该做的是打印一条错误消息并返回。

您在查询中也有错误,例如在创建需要用括号结束的表时。

最后,如果你打算使用用户提供的数据,不要直接构建查询,因为你的系统容易出现 SQL 注入(inject),使用绑定(bind)值是合适的。

QSqlDatabase db_kon = QSqlDatabase::addDatabase("QSQLITE");
db_kon.setDatabaseName("C:/Users/Lukasz/Desktop/qt master/organizator/baza_kontakty.db");

if(!db_kon.open()){
    qDebug() << "error:" << db_kon.lastError().text();
    return;
}

qDebug() << "Success";

QSqlQuery query;
query.prepare( "CREATE TABLE kontakty(ids INTEGER PRIMARY KEY, name TEXT, surname TEXT, company TEXT, email TEXT, phone TEXT)");

if(!query.exec()){
    qDebug()<<"error:" << query.lastError().text();
    return;
}

QString name = ui->lineEdit_name->text();
QString surname = ui->lineEdit_surname->text();
QString company = ui->lineEdit_company->text();
QString email = ui->lineEdit_email->text();
QString phone = ui->lineEdit_phone->text();

if(name.isEmpty() &&
        surname.isEmpty() &&
        email.isEmpty() &&
        phone.isEmpty() &&
        company.isEmpty())
{
    QMessageBox::critical(this, tr("Error"), tr("Complete all fields!"));
    return;
}

query.prepare("INSERT INTO kontakty(name, surname, company, email, phone) VALUES(?, ?, ?, ?, ?)");

query.addBindValue(name);
query.addBindValue(surname);
query.addBindValue(company);
query.addBindValue(email);
query.addBindValue(phone);

if(query.exec())
    QMessageBox::information(this, tr("Success"),tr(" A new contact has been added"));
else
    QMessageBox::information(this, tr("Error"),tr("It was not possible to add a new contact"));

关于c++ - Qt & Sqlite 向数据库中插入数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50861294/

相关文章:

android - 从 Internet 下载 SQLite 数据库并加载到 Android 应用程序中

c# - 如何将两个不同的项目指向同一个 SQLite 数据库文件?

sql - 如何使 SQL JOIN 仅返回具有最新状态代码的一行?

c++ - 无法将发布的值存储到 vector

c++ - 证书链的根证书是自签名的,不受信任的

c++ - 如何初始化指向对象的动态指针数组?

c++ - Qt中用指针改变布局内容

qt - 父级之上的无模式 Qt 窗口,但不在其他应用程序之上

c++ - 创建网格数组

c++ - COM 组件崩溃