【问题标题】:connection sql database in qt in visual studio在visual studio中的qt中连接sql数据库
【发布时间】:2015-12-09 14:40:14
【问题描述】:

我开始在 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();
}

好吧,当我尝试调试时,我得到了这个奇怪的错误。我不知道是我的代码问题还是 qt 安装错误。

错误:

错误 2 错误 LNK2019:无法解析的外部符号 "__declspec(dllimport) 公共:__cdecl QSqlDatabase::~QSqlDatabase(void)" (__imp_??1QSqlDatabase@@QEAA@XZ) 在函数“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

错误 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) 公共:无效 __cdecl QSqlDatabase::setDatabaseName(类 QString const &)" (__imp_?setDatabaseName@QSqlDatabase@@QEAAXAEBVQString@@@Z) 引用 在函数“私人:无效__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) public: 静态类 QSqlDatabase __cdecl QSqlDatabase::addDatabase(class QString const &,class 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) 公共:静态字符 * 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

【问题讨论】:

    标签: c++ qt visual-studio-2013 sql-server-2012


    【解决方案1】:

    您的项目可能缺少 QtSql.lib 依赖项。在 VS 的项目配置中的某个地方,您应该可以添加链接器附加依赖项 - 该库应该位于您的 Qt 安装目录(Qt/lib)中。希望对您有所帮助。

    【讨论】:

      【解决方案2】:

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

      简而言之,每当您收到“未解析的外部符号”错误时,这都是链接器生成的错误,这意味着您在项目设置中遗漏了某种库。

      Qt 带有一系列模块,这些模块被组织到不同的库中。 QSql 模块只是其中之一。

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

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

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

      1. Qt5Sqld.lib 到 Debug 配置
      2. Qt5Sql.lib 到 Release 配置

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        相关资源
        最近更新 更多