0

name4 つのフィールド ( 、lastnamesemesterおよび)を持つ Student という名前のデータベースがありますstudentid

ユーザーが学生をデータベースに挿入し、挿入後にテーブルに学生を表示するオプションを使用できるようにするアプリケーションを接続しています。

テーブルには、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));
}

MainWindow.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();
}

//Reload table は、削除された学生なしで新しいデータベースを表示するために、delete 関数の後に呼び出されます。

学生.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.exec(QString("DROP TABLE student;"));

テーブルは削除ボタンの後で問題なく削除されるため、studentid またはクエリに何か問題がありますか? すべてのテーブルではなく、個々の挿入を削除する必要があります。

4

1 に答える 1