0
点赞
收藏
分享

微信扫一扫

Qt5.12实战之访问Access数据库


1.下载并安装Access数据库引擎64位:

Download Microsoft Access 2016 数据库引擎可再发行程序包 from Official Microsoft Download Center

Qt5.12实战之访问Access数据库_sql

 

Qt5.12实战之访问Access数据库_sql_02

 下载好后安装在开发机上:

Qt5.12实战之访问Access数据库_Access_03

Access引擎安装成功. 

Qt5.12实战之访问Access数据库_数据库_04

 

Qt5.12实战之访问Access数据库_sql_05

 配置Access数据库

Qt5.12实战之访问Access数据库_sql_06

这样就可直接通过配置名来访问数据库了:

  

sql.setDatabaseName("carddb");

成功访问效果:

Qt5.12实战之访问Access数据库_数据库_07

如果没有配置用户DSN ,也可直接用连接字符串来访问,效果一样:

sql.setDatabaseName("DRIVER={Microsoft Access Driver (*.mdb, *.accdb)};FIL={MS Access};DBQ=C:\\Users\\dev\\Desktop\\carddb.accdb");

 

Qt5.12实战之访问Access数据库_数据库_08

实现代码:

#include <QCoreApplication>
#include <QDebug>
//数据库相当头文件
#include <QtSql/QSqlDatabase>
#include <QSqlDriver>
#include <QSqlError>

int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);
    //"Qt 5.12所支持的数据库:"
    //"驱动名:QSQLITE"
    //"驱动名:QODBC"
    //"驱动名:QODBC3"
    //"驱动名:QPSQL"
    //"驱动名:QPSQL7"
    qDebug()<<QStringLiteral("Qt 5.12所支持的数据库:");
    for(QString drv:QSqlDatabase::drivers()){
        qDebug()<<QStringLiteral("驱动名:%1").arg(drv);
    }
    //先安装ms-office,然后用access创建数据库与表
    //声明数据库对象
    QSqlDatabase sql;
    //指定要访问的数据库类型,使用ODBC驱动
    sql = QSqlDatabase::addDatabase("QODBC");

    if(!sql.isValid()){
        qDebug()<<QStringLiteral("读取数据库出错");
    }
    //sql.setDatabaseName("carddb");
    sql.setDatabaseName("DRIVER={Microsoft Access Driver (*.mdb, *.accdb)};FIL={MS Access};DBQ=C:\\Users\\dev\\Desktop\\carddb.accdb");
    //打开数据库
    if(sql.open()){
        qDebug()<<QStringLiteral("打开Access数据库成功");
    }else{
        QSqlError err = sql.lastError();
        qDebug()<<QStringLiteral("打开Access数据库失败:%1").arg(err.driverText());
    }
    return a.exec();
}

数据库设计:

Qt5.12实战之访问Access数据库_数据库_09

 

数据库访问

Qt5.12实战之访问Access数据库_Access_10

 

举报

相关推荐

0 条评论