gpt4 book ai didi

c++ - 试图从 QT 表上的数据库中删除

转载 作者:行者123 更新时间:2023-11-28 05:06:17 25 4
gpt4 key购买 nike

我有一个名为 student 的数据库,其中包含 4 个字段(namelastnamesemesterstudentid)。

我连接了一个应用程序,它允许用户在数据库中插入学生,并可以选择在插入后将他们显示在表格中。

表格为每个插入学生都有一个DELETE 按钮,我已将其连接到单独的函数,让用户可以选择根据studentid 删除个别学生。

问题是我似乎做错了什么,因为删除按钮在单击时不起作用。不过我没有收到任何错误,所以我需要你的帮助来查找错误。

数据库创建代码:

Database::Database()
{
db = QSqlDatabase::addDatabase("QSQLITE");
db.setDatabaseName("students.db");
db.open();
QSqlQuery q(db);
q.exec(QString("DROP TABLE student;"));

q.exec(QString("create table if not exists student(")+
QString("id integer primary key autoincrement,")+
QString("name varchar(1024),lastname varchar(1024),semester integer,")+
QString("studentid integer)"));
}

从database.cpp调用的数据库中删除

void    Database::deleteStudent(int id)
{
QSqlQuery query(db);
query.exec("DELETE student where studentid="+QString::number(id));
}

主窗口.cpp

//创建插入的表列表

    void    MainWindow::makeDisplayForm()
{
QWidget *tab2=new QWidget;
panel->addWidget(tab2);
tab2->setFixedSize(95*this->size().width()/100,this->size().height()/2);
QVBoxLayout *tab2layout=new QVBoxLayout;
tab2->setLayout(tab2layout);
table=new QTableWidget;
table->setRowCount(1);
table->setColumnCount(5);
QStringList header;
header<<"NAME"<<"LASTNAME"<<"SEMESTER"<<"ID"<<"DELETE";
table->setHorizontalHeaderLabels(header);
tab2layout->addWidget(table);
}

void MainWindow::reloadTable()
{
QVector<Student> p=mydb->students();
table->clearContents();
table->setRowCount(p.size());
for(int i=0;i<p.size();i++)
{
Student pt=p[i];
QLineEdit *tableName=new QLineEdit;
tableName->setText(pt.getname());
table->setCellWidget(i,0,tableName);

QLineEdit *tableLastName=new QLineEdit;
tableLastName->setText(pt.getlastname());
table->setCellWidget(i,1,tableLastName);


table->setItem(i,2,new QTableWidgetItem(QString::number(pt.getsemester())));
table->setItem(i,3,new QTableWidgetItem(QString::number(pt.getstudentid())));

//DELETE BUTTON CREATE
QPushButton *deleteButton=new QPushButton;
deleteButton->setText("DELETE");
connect(deleteButton,SIGNAL(clicked(bool)),this,SLOT(deleteSlot()));
deleteButton->setProperty("STUDENTID",pt.getstudentid());
table->setCellWidget(i,4,deleteButton);

}
}

//DELETE按钮连接函数。

void    MainWindow::deleteSlot()
{
QPushButton *b=(QPushButton *)sender();
int studtid=b->property("STUDENTID").toInt();
mydb->deleteStudent(studtid);
reloadTable();
}

//在删除函数后调用重新加载表,以显示没有删除学生的新数据库。

学生.cpp

#include "student.h"

Student::Student()
{
name="";
lastname="";
studentid=0;
semester=0;
}

Student::Student(QString n,QString l,int s,int p)
{
name=n;
lastname=l;
semester=s;
studentid=p;
}

int Student::getstudentid()
{
return studentid;
}

更新:如果我将 void Database::deleteStudent(int id)query 更改为:

query.exec(QString("DROP TABLE student;"));

表在删除按钮后被删除得很好所以它的学生 ID 或查询有问题吗?我需要删除单个插入而不是整个表。

最佳答案

在你的函数中试试这个:

DELETE FROM student WHERE studentid=....

关于c++ - 试图从 QT 表上的数据库中删除,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44682940/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com