10.23作业

#include "widget.h"
#include "ui_widget.h"

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
    //判断数据库是否存在
    if(!db.contains())
    {
        //说明数据库不存在
        //创建一个数据库
        db=QSqlDatabase::addDatabase("QSQLITE");//表示数据库驱动为sqllite3

        //给创建的数据库命名
        db.setDatabaseName("stuInfo.db");
        QMessageBox::information(this,"","创建数据库成功");

    }

    //打开数据库
    if(!db.open())
    {
        QMessageBox::information(this,"","打开数据库失败");
        return ;
    }

    //给数据库创建数据库表
    //实例化一个执行sql语句的类对象 QSqlQuer类
    QSqlQuery query;


    QString sql = "create table if not exists stu_info_table("
                     "id integer primary key autoincrement,"
                     "numb integer,"
                     "name varchar(20),"
                     "sex varchar(4),"
                     "score integer)";
       //执行sql语句
       if(query.exec(sql))
       {
           QMessageBox::information(this,"","创建数据表成功");
       }
       else
       {
           QMessageBox::information(this,"","创建数据表失败");
       }








}

Widget::~Widget()
{
    delete ui;
}

//添加按钮对应的槽函数处理
void Widget::on_addBtn_clicked()
{
    //获取ui界面行的信息
   int numb = ui->numbEdit->text().toUInt();
   QString name=ui->nameEdit->text();
   QString sex=ui->sexEdit->text();
   int score=ui->scoreEdit->text().toUInt();
   //保证用户输入完整信息
   if(numb==0 || name.isEmpty() || sex.isEmpty() || score==0)
   {
       QMessageBox::information(this,"","请将信息填写完整");
       return ;
   }
   //将信息保存到数据库中
   //需要一个实例化一个执行sql语句的类对象
   QSqlQuery query;
   //准备sql语句
   QString sql = QString("insert into stu_info_table(numb,name,sex,score) "
                             "values(%1,'%2','%3',%4)")
                               .arg(numb).arg(name).arg(sex).arg(score);

   //执行sql语句
   if(query.exec(sql))
   {
       QMessageBox::information(this,"","添加成功");
   }
   else
   {
       QMessageBox::information(this,"","添加失败");
   }



}
//显示按钮对应的槽函数处理
void Widget::on_showBtn_clicked()
{
    //实例化一个执行sql语句的类对象
    QSqlQuery query;
    //准备sql语句
    QString sql="select * from stu_info_table";

    //执行sqk语句
    if(query.exec(sql))
    {
        //将数据库里的内容放入ui界面上

        int i=0;//记录行号

        while(query.next())//next遍历内容
        {
            for(int j=0;jtableWidget->setItem(i,j,new QTableWidgetItem(query.value(j+1).toString()));
            }
            i++;
        }
    }
}

//删除按钮对应的槽函数处理
void Widget::on_delBtn_clicked()
{
    //获取ui界面行的信息
    int numb = ui->numbEdit->text().toUInt();

    //实例化一个执行sql语句的类对象
    QSqlQuery query;
    //准备sql语句
    QString sql = QString("delete from stu_info_table where numb='%1'").arg(numb);

    if(query.exec(sql))
    {
        QMessageBox::information(this,"","删除成功");
    }
    else
    {
        QMessageBox::information(this,"","删除失败");
    }





}

//查找按钮对应的槽函数处理
void Widget::on_lookBtn_clicked()
{

    //获取ui界面行的信息
    int numb = ui->numbEdit->text().toUInt();

    //实例化一个执行sql语句的类对象
    QSqlQuery query;
    //准备sql语句
    QString sql = QString("select * from stu_info_table where numb = '%1' ").arg(numb);
    ui->tableWidget->clear();


    //执行sql语句
    if(query.exec(sql))
    {
        QMessageBox::information(this,"","查找成功");
        //将数据库里的内容放入ui界面上

        int i=0;//记录行号

        while(query.next())//next遍历内容
        {

            for(int j=0;jtableWidget->setItem(i,j,new QTableWidgetItem(query.value(j+1).toString()));
            }
            i++;
        }
    }

}

10.23作业_第1张图片

10.23作业_第2张图片

你可能感兴趣的:(c++)