QT 连接ACCESS数据库(OCDB)
文章转自王牌软件
站长推荐:NSetup一键部署软件
一键式完成美化安装包制作,自动增量升级,数据统计,数字签名。应对各种复杂场景,脚本模块化拆分,常规复杂的脚本代码,图形化设置。无需专业的研发经验,轻松完成项目部署。(www.nsetup.cn)
只回答业务咨询
站长推荐:NSetup一键部署软件
一键式完成美化安装包制作,自动增量升级,数据统计,数字签名。应对各种复杂场景,脚本模块化拆分,常规复杂的脚本代码,图形化设置。无需专业的研发经验,轻松完成项目部署。(www.nsetup.cn)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 |
/*@版权说明 国防科技大学 信息系统与管理学院仿真工程研究所 平行系统研究中心 版权@所有 */ /*功能说明 文件名称:AccessDB.h 作 者:杨泽 联系方式:yangze.3344@163.com 创建时间:2014.12.04 17:28 目 的:用于气象数据的数据库操作 功能描述:实现Access数据库的基本操作 约束条件:该编码使用了C++11特性,因此编译平台必须支持C++11标准,使用QT mingw32编译器 */ #ifndef ACCESSDB_H #define ACCESSDB_H #include <QtSql> class AccessDB{ public: AccessDB(); bool connectDB(const QString& DatabasePath, const QString& connectName, const QString& HostName = "", const QString& UserName = "", const QString& Password = ""); bool queryDB(const QString &query); void newQuery(); //bool insertData(const QString &insert); bool openDB(const QString& connectName); //void closeDB(const QString& connectName); void closeDB(); QSqlDatabase connection; QSqlQuery *m_query; QString idName; }; #endif // ACCESSDB_H |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 |
#include "AccessDB.h" #include <QMessageBox> #include "Externs.h" AccessDB::AccessDB() { } bool AccessDB::connectDB(const QString& DatabasePath, const QString& connectName, const QString& HostName, const QString& UserName, const QString& Password) { const QString connID(connectName); //QString connID = PREFIX +"-"+DatabasePath; connection = QSqlDatabase::database(connID,false); if(connection.isValid()) { if(connection.isOpen()) return true; } else { connection = QSqlDatabase::addDatabase("QODBC",connID); QString dsn = QString("DRIVER={Microsoft Access Driver (*.mdb)};FIL={Meteorology Access};DBQ=%1;UID=;PWD=%2") .arg(DatabasePath).arg(Password); connection.setDatabaseName(dsn); //connection.setUserName(UserName); //connection.setPassword(Password); if(!connection.open()) { QMessageBox::critical(0,QObject::tr("Database Error"),connection.lastError().text()); return false; } else { newQuery(); return true; } } } void AccessDB::newQuery() { m_query = new QSqlQuery(connection); } bool AccessDB::queryDB(const QString &query) { if(!m_query->prepare(query))//如果加载失败,刚断开连接,然后再连接 { connection.close(); if(!openDB(idName)) { return false; } qDebug()<<"new.....Connect"; } return(m_query->exec()); } bool AccessDB::openDB(const QString& connectName) { idName = connectName; if(!connectDB(dbName,idName,"","",password)) { QMessageBox msgBox; msgBox.setText("数据库连接失败"); msgBox.setIcon(QMessageBox::Warning); msgBox.setStandardButtons(QMessageBox::Ok | QMessageBox::Cancel); msgBox.setDefaultButton(QMessageBox::Ok); msgBox.exec(); return false; } return true; } void AccessDB::closeDB() { const QString connID(idName); //connection = QSqlDatabase::database(connID,false); connection.close(); connection.removeDatabase(connID); } |
学习日记,兼职软件设计,软件修改,毕业设计。
本文出自 学习日记,转载时请注明出处及相应链接。
本文永久链接: https://www.softwareace.cn/?p=1212