#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;j<query.record().count();j++)
{
ui->tableWidget->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;j<query.record().count();j++)
{
ui->tableWidget->setItem(i,j,new QTableWidgetItem(query.value(j+1).toString()));
}
i++;
}
}
}
10.23作业
最新推荐文章于 2024-08-02 20:41:30 发布