在Visual Studio中的qt中连接sql数据库

use*_*392 4 c++ qt sql-server-2012 visual-studio-2013

我开始在 Visual Studio C++ (2013) 中编程,并使用 Qt(5.5.0) 作为用户界面。我正在尝试连接到我的 sql server 数据库 (sql server 2012) 。

根据文档,它应该很简单。这是我的代码:

#include "qt_test1.h"
//#include "ui_qt_test1.h"
#include <qmessagebox.h>
#include <qfiledialog.h>
#include <QtGui>
#include <QtSql\qsql.h>
#include <QtSql\qsqldatabase.h>
#include <QtSql\qsqlerror.h>
#include <qdebug.h>

qt_test1::qt_test1(QWidget *parent)
: QMainWindow(parent)
{
    ui.setupUi(this);

}

qt_test1::~qt_test1()
{

}

// when button clicked try to connect to database
void qt_test1::on_btnShowHello_clicked()
{

    QSqlDatabase db = QSqlDatabase::addDatabase("mydb");
    db.setDatabaseName("C:\\Program Files\\Microsoft SQL Server\\MSSQL11.MSSQLSERVER\\MSSQL\\DATA\\qt_test_db");

    bool ok = db.open();
}
Run Code Online (Sandbox Code Playgroud)

好吧,当我尝试调试时,我遇到了这个奇怪的错误。它缺少 dll 的东西,我不知道这是我的代码问题还是 qt 安装错误。

错误:

错误2错误LNK2019:无法解析的外部符号“__declspec(dllimport)公共:__cdecl QSqlDatabase ::〜QSqlDatabase(void)”(__imp_??1QSqlDatabase@@QEAA@XZ)在函数“私有:void __cdecl qt_test1 :: on_btnShowHello_clicked(void)中引用)" (?on_btnShowHello_clicked@qt_test1@@AEAAXXZ) E:\Project\qt_test1\qt_test1\qt_test1.obj qt_test1

错误 3 错误 LNK2019:无法解析的外部符号“__declspec(dllimport) public: bool __cdecl QSqlDatabase::open(void)” (__imp_?open@QSqlDatabase@@QEAA_NXZ) 在函数“private: void __cdecl qt_test1::on_btnShowHello_clicked(void)”中引用“ (?on_btnShowHello_clicked@qt_test1@@AEAAXXZ) E:\Project\qt_test1\qt_test1\qt_test1.obj qt_test1

错误 4 错误 LNK2019:无法解析的外部符号“__declspec(dllimport) public: void __cdecl QSqlDatabase::setDatabaseName(class QString const &)”(__imp_?setDatabaseName@QSqlDatabase@@QEAAXAEBVQString@@@Z) 在函数“private: void __cdecl”中引用qt_test1::on_btnShowHello_clicked(void)" (?on_btnShowHello_clicked@qt_test1@@AEAAXXZ) E:\Project\qt_test1\qt_test1\qt_test1.obj qt_test1

错误5错误LNK2019:无法解析的外部符号“__declspec(dllimport)公共:静态类QSqlDatabase __cdecl QSqlDatabase :: addDatabase(类QString const&,类QString const&)”(__imp_?addDatabase@QSqlDatabase@@SA?AV1@AEBVQString@@ 0@Z) 在函数“private: void __cdecl qt_test1::on_btnShowHello_clicked(void)”中引用 (?on_btnShowHello_clicked@qt_test1@@AEAAXXZ) E:\Project\qt_test1\qt_test1\qt_test1.obj qt_test1

错误6错误LNK2001:无法解析的外部符号“__declspec(dllimport) public: static char * QSqlDatabase::defaultConnection”(__imp_?defaultConnection@QSqlDatabase@@2PEADEA) E:\Project\qt_test1\qt_test1\qt_test1.obj qt_test1

错误 7 错误 LNK1120: 5 个无法解析的外部 E:\Project\qt_test1\x64\Debug\qt_test1.exe qt_test1

Rob*_*ieE 7

这不是您的代码,也不是 Qt 安装。你只是不明白C/C++是如何编译程序的。我建议您研究一下预编译器、编译器和链接器的工作原理,以填补您的知识空白。

简而言之,每当您收到“无法解析的外部符号”错误时,这是​​链接器生成的错误,这意味着您已将某种库排除在项目设置之外。

Qt 附带了一整套模块,这些模块被组织到不同的库中。该QSql模块只是其中之一。

如果您有 Qt 的 Visual Studio 插件,则很容易修复:只需右键单击您的项目,选择Qt Project Settings,然后在选项卡SQL上进行选择Qt Modules

如果您没有安装加载项,则必须手动添加依赖项。

右键单击您的项目,选择Properties。展开Configuration properties,然后展开Linker并选择Input。在 中Additional Dependencies,添加:

  1. Qt5Sqld.lib 到调试配置
  2. Qt5Sql.lib 到 Release 配置