QT--SQLite
配置类相关的表,所以我使用sqlite,且QT自带该组件;
1.安装 sqlite-tools-win-x64-3460000、SQLiteExpert5.4.31.575
使用SQLiteExpert建好数据库.db文件,和对应的表后把db文件放在指定目录 ./db/program.db;
2.选择sql组件
3.新增数据库处理类,在使用数据库的地方调用类成员函数即可
DataModel::DataModel()
{
db = QSqlDatabase::addDatabase("QSQLITE", "");
db.setDatabaseName("./db/program.db");
connectDataBase();
}
DataModel::~DataModel()
{
disconnectDataBase();
}
// 打开数据库文件
bool DataModel::connectDataBase() {
bool ret = db.open();
if (!ret) {
outPutMsg(QtDebugMsg, "DataModel::connectDataBase error = " + db.lastError().text());
}
return ret;
}
// 关闭数据库文件
void DataModel::disconnectDataBase() {
db.close();
}
QStringList DataModel::queryProgramList() {
QStringList programList;
// 根据名字查询
QString sql = QString("select sectionBarName,programNo from program where 1=1;");
outPutMsg(QtDebugMsg, "DataModel::queryProgramList sql = " + sql);
// 创建一个可以对db执行语句的对象
QSqlQuery query(db);
// 执行sql语句
bool ret = query.exec(sql);
if (!ret)
{
outPutMsg(QtDebugMsg, "DataModel::queryProgramNo error = " + query.lastError().text());
return programList;
}
// 行坐标向下移
while (query.next())
{
//获取数据库query所指的那行的数据
QString program;
program += (query.value(0).toString() + ";"); // sectionBarName
program += QString::number(query.value(1).toInt()); // programNo
// outPutMsg(QtDebugMsg, "DataModel::queryProgramInfoBySectionCode programInfo = " + program);
programList.append(program);
}
return programList;
}
// 根据型材代号查询程序号码
QString DataModel::queryProgramNo(QString sectionBarNo) {
// 根据名字查询
QString sql = QString("select programNo from program where sectionBarName=\'%1\';").arg(sectionBarNo);
//QString sql = QString("select programNo from program where 1=1");
outPutMsg(QtDebugMsg, "DataModel::queryProgramNo sql = " + sql);
// 创建一个可以对db执行语句的对象
QSqlQuery query(db);
// 执行sql语句
bool ret = query.exec(sql);
if (!ret)
{
outPutMsg(QtDebugMsg, "DataModel::queryProgramNo error = " + query.lastError().text());
return "";
}
QString programNo = "";
// 行坐标向下移
while (query.next())
{
//获取数据库query所指的那行的数据
programNo = QString::number(query.value(0).toInt());
outPutMsg(QtDebugMsg, "DataModel::queryProgramNo programNo = " + programNo);
}
return programNo;
}
// 根据程序号码查询
QString DataModel::queryProgramByNo(QString programNo) {
// 根据名字查询
QString sql = QString("select sectionBarName from program where programNo=\'%1\';").arg(programNo);
//QString sql = QString("select programNo from program where 1=1");
outPutMsg(QtDebugMsg, "DataModel::queryProgramByNo sql = " + sql);
// 创建一个可以对db执行语句的对象
QSqlQuery query(db);
// 执行sql语句
bool ret = query.exec(sql);
if (!ret)
{
outPutMsg(QtDebugMsg, "DataModel::queryProgramByNo error = " + query.lastError().text());
return "";
}
QString sectionBarNo = "";
// 行坐标向下移
while (query.next())
{
//获取数据库query所指的那行的数据
sectionBarNo = QString::number(query.value(0).toInt());
outPutMsg(QtDebugMsg, "DataModel::queryProgramByNo sectionBarNo = " + sectionBarNo);
}
return sectionBarNo;
}
// 根据型材代号查询程序号码
QStringList DataModel::queryProgramInfoBySectionCode(QString sectionBarNo) {
QStringList programInfoList;
// 根据名字查询
// 使用索引sectionBarName
QString sql = QString("select stepNo, cutNo,x, y, f, Rx, Ry from programInfo where programNo = (select programNo from program where sectionBarName=\'%1\');").arg(sectionBarNo);
//QString sql = QString("select programNo from program where 1=1");
outPutMsg(QtDebugMsg, "DataModel::queryProgramInfoBySectionCode sql = " + sql);
// 创建一个可以对db执行语句的对象
QSqlQuery query(db);
// 执行sql语句
bool ret = query.exec(sql);
if (!ret)
{
outPutMsg(QtDebugMsg, "DataModel::queryProgramInfoBySectionCode error = " + query.lastError().text());
return programInfoList;
}
// 行坐标向下移
while (query.next())
{
//获取数据库query所指的那行的数据
QString programInfo;
programInfo += (QString::number(query.value(0).toInt())+";"); // stepNo
programInfo += (QString::number(query.value(1).toInt())+";"); // cutNo
programInfo += (QString::number(query.value(2).toDouble(), 'f', 2) + ";"); // x
programInfo += (QString::number(query.value(3).toDouble(), 'f', 2) + ";"); // y
programInfo += (QString::number(query.value(4).toDouble(), 'f', 2) + ";"); // f 速度
programInfo += (QString::number(query.value(5).toDouble(), 'f', 2) + ";"); // Rx
programInfo += (QString::number(query.value(6).toDouble(), 'f', 2)); // Ry
outPutMsg(QtDebugMsg, "DataModel::queryProgramInfoBySectionCode programInfo = " + programInfo);
programInfoList.append(programInfo);
}
return programInfoList;
}
// 更新程序信息
bool DataModel::updateProInfosByProNo(QString proNo, QStringList proInfoList) {
// 开启事务
if (!db.transaction()) {
outPutMsg(QtDebugMsg, "DataModel::updateProInfosByProNo db.error = " + db.lastError().text());
return false;
}
QStringList programInfoList;
// 根据名字查询
// 使用索引sectionBarName
QString sqlDel = QString("delete from programInfo where programNo=\'%1\';").arg(proNo);
outPutMsg(QtDebugMsg, "DataModel::updateProInfosByProNo sqlDel = " + sqlDel);
// 创建一个可以对db执行语句的对象
QSqlQuery query(db);
// 执行sql语句
bool ret = query.exec(sqlDel);
if (!ret)
{
outPutMsg(QtDebugMsg, "DataModel::updateProInfosByProNo error = " + query.lastError().text());
return false;
}
try {
for (int i = 0; i 0) {
sqlOne += ",";
}
sqlOne += programInfo.at(j) ;
}
sqlOne += ");";
outPutMsg(QtDebugMsg, "DataModel::updateProInfosByProNo sqlOne = " + sqlOne);
if (!query.exec(sqlOne))
{
outPutMsg(QtDebugMsg, "DataModel::updateProInfosByProNo error = " + query.lastError().text());
return false;
}
}
}
catch (...) {
outPutMsg(QtDebugMsg, "DataModel::updateProInfosByProNo error = " + query.lastError().text());
return false;
}
// 开启事务
if (!db.commit()) {
outPutMsg(QtDebugMsg, "DataModel::updateProInfosByProNo db.error = " + db.lastError().text());
return false;
}
return true;
}
// 保存程序信息
void ClearCorner::on_edit_saveBtn_clicked() {
QStringList proInfoList;
for (int i = 0; i 0) {
strTmp += ";";
}
strTmp += item->text();
}
outPutMsg(QtDebugMsg, "ClearCorner::on_edit_saveBtn_clicked strTmp = " + strTmp);
proInfoList.append(strTmp);
}
DataModel dataModel;
bool ret = dataModel.updateProInfosByProNo(ui.edit_lineEdit_programNo->text(), proInfoList);
if (ret) {
QMessageBox::information(nullptr, "提示", "更新程序成功!");
}
else {
QMessageBox::warning(nullptr, "提示", "更新程序失败!");
}
}
免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!

