目录
基础
头文件
模块
编程步骤
实战
ui界面
ui界面的成员定义
构造函数初始化准备
在ui界面类析构函数里关闭数据库
添加按钮
删除按钮
改按钮
查询按钮
效果
基础
现在常用的是sqlite是sqlite 3,我用的是sqlite 3
数据库文件是以db结尾的
查看数据库文件软件下载路径
SQLite administration | SQLite Experthttps://www.sqliteexpert.com/download.html
头文件
#include
模块
QT += core gui sql
编程步骤
- 连接数据库,并且要指定要连接哪一个数据库
- 打开数据库文件,如果文件不存在,则创建
- 创建表
- 增删改查
实战
ui界面
ui界面的成员定义
#include
#include #include #include private: QSqlDatabase db;//数据库文件 构造函数初始化准备
//1、连接数据库,指定你要操作的数据库的类型 并且设置数据库文件的名字 //第二个参数不写,指的是该数据库文件 是这个工程默认操作的数据库文件 db = QSqlDatabase::addDatabase("QSQLITE","a1"); //第二个参数指的是连接名称,其实就是标识符 //指定操控的数据库文件,没有则创建,如果用db.open打开文件要密码 db.setDatabaseName("company.db"); //2、打开数据库文件 if(db.open()==false) { //db.lastError()错误的原因 qDebug()<<"open error:"<
在ui界面类析构函数里关闭数据库
//关闭数据库 db.close();
添加按钮
//1、获取控件的数据 int id = ui->lineEdit_id->text().toInt(); QString name = ui->lineEdit_name->text(); QString address = ui->lineEdit_address->text(); double salary = ui->lineEdit_salary->text().toDouble(); //2、准备添加sql语句 QString sql = QString("insert into staff values(%1,'%2','%3',%4);").arg(id).arg(name).arg(address).arg(salary); //创建一个可以对db执行语句的对象 QSqlQuery query(db); //执行sql语句 bool ret = query.exec(sql); if(ret == false) { qDebug()<<"insert into error "<
删除按钮
//以ID作为唯一的标识 ,删除ID所在行的那一条记录 int id = ui->lineEdit_id->text().toInt(); //删除语句 QString sql = QString("delete from staff where id=%1;").arg(id); //创建一个可以对db执行语句的对象 QSqlQuery query(db); //执行sql语句 bool ret = query.exec(sql); if(ret == false) { qDebug()<<"delete error "<
改按钮
//以ID作为唯一的标识 ,更新其他的数据 int id = ui->lineEdit_id->text().toInt(); QString updateName = ui->lineEdit_name->text(); QString updateAddress = ui->lineEdit_address->text(); double salary = ui->lineEdit_salary->text().toDouble(); //组合更新sql语句 QString sql = QString("update staff set name='%1',address='%2',salary=%3 where id=%4;") .arg(updateName) .arg(updateAddress) .arg(salary) .arg(id); //创建一个可以对db执行语句的对象 QSqlQuery query(db); //执行sql语句 bool ret = query.exec(sql); if(ret == false) { qDebug()<<"update error "<
查询按钮
//根据名字查询 QString sql = QString("select * from staff where name=\"%1\";").arg(ui->lineEdit_name->text()); //创建一个可以对db执行语句的对象 QSqlQuery query(db); //执行sql语句 bool ret = query.exec(sql); if(ret == false) { qDebug()<<"select error "<
效果
猜你喜欢
- 16天前(大理悦云雅阁酒店电话)雅阁酒店集团|端午佳节礼遇,大理悦云雅阁度假酒店
- 16天前(2020海丝之路文化博览会)2023海丝之路文化和旅游博览会开幕
- 16天前(“清透会呼吸”轻松拿捏春日出游氛围感)“清透会呼吸”轻松拿捏春日出游氛围感
- 16天前(071 圣安东尼奥)秋季 圣安东尼奥交出了私藏活动清单
- 16天前(曼谷丽思卡尔顿公寓价格)曼谷丽思卡尔顿酒店盛大启幕,开创泰国奢华雅致新纪元
- 16天前(马尔代夫华尔道夫酒店多少钱)Chef Zhao就任马尔代夫伊挞富士岛华尔道夫酒店Li Long中餐厅新主厨
- 16天前(澳涞坞是什么)从最美山庄到世界舞台:澳涞山庄见证世界十佳旅居城市评选
- 16天前(万豪旅享家活动2021)精彩上新,漫享夏日----跟随万豪旅享家新开酒店解锁夏日旅行灵感
- 16天前(美诺酒店集团旗下臻选品牌m collection)美诺酒店集团启动盛橡品牌战略焕新 开启全球扩张新篇章
- 16天前(2025年安徽省“百场黄梅唱响百家景区”示范展示启动)2025年安徽省“百场黄梅唱响百家景区”示范展示启动
网友评论
- 搜索
- 最新文章
- (2020广州车展哈弗)你的猛龙 独一无二 哈弗猛龙广州车展闪耀登场
- (哈弗新能源suv2019款)智能科技颠覆出行体验 哈弗重塑新能源越野SUV价值认知
- (2021款全新哈弗h5自动四驱报价)新哈弗H5再赴保障之旅,无惧冰雪护航哈弗全民电四驱挑战赛
- (海南航空现况怎样)用一场直播找到市场扩张新渠道,海南航空做对了什么?
- (visa jcb 日本)优惠面面俱到 JCB信用卡邀您畅玩日本冰雪季
- (第三届“堡里有年味·回村过大年”民俗花灯会活动)第三届“堡里有年味·回村过大年”民俗花灯会活动
- (展示非遗魅力 长安启源助力铜梁龙舞出征)展示非遗魅力 长安启源助力铜梁龙舞出征
- (阿斯塔纳航空公司)阿斯塔纳航空机队飞机数量增至50架
- (北京香港航班动态查询)香港快运航空北京大兴新航线今日首航
- (我在港航“呵护”飞机 每一次安全着陆就是最好的荣誉)我在港航“呵护”飞机 每一次安全着陆就是最好的荣誉
- 热门文章