Qt走起 - QT与数据库 - QT数据库入门
error: 'QSqlDatabase' file not found 解决办法
下面以QT CMake Widgets应用程序为例子说明解决方法。
使用QT Creator建立项目时选择Build System为CMake,如下图:


QT CMAKE项目,如果需要使用Qt的数据库功能,一般会添加以下语句:
#include <QSqlDatabase>


如果直接在源代码中添加以上语句,可能会引发报错:
error: 'QSqlDatabase' file not found

怎么解决这个问题呢?

就是在CMakeList.txt文件中添加对sql引用的,打开CMakeList.txt添加以下语句:

find_package(Qt${QT_VERSION_MAJOR} COMPONENTS Sql REQUIRED)

target_link_libraries(HtDbHelper PRIVATE Qt${QT_VERSION_MAJOR}::Sql)

这里HtDbHelper是项目名称,请根据实际情况修改。
这两条语句各自加在对应的位置

总结,QT Creator 创建Widgets应用程序时,选择CMake构建系统,使用QSQLDatabase时,需要修改CMakeList.txt文件,代码如下:
cmake_minimum_required(VERSION 3.5)

project(HtDbHelper VERSION 0.1 LANGUAGES CXX)

set(CMAKE_INCLUDE_CURRENT_DIR ON)

set(CMAKE_AUTOUIC ON)
set(CMAKE_AUTOMOC ON)
set(CMAKE_AUTORCC ON)

set(CMAKE_CXX_STANDARD 11)
set(CMAKE_CXX_STANDARD_REQUIRED ON)

#包的引用如下
#by 何问起
# hovertree.com

find_package(QT NAMES Qt6 Qt5 COMPONENTS Widgets REQUIRED)
find_package(Qt${QT_VERSION_MAJOR} COMPONENTS Widgets REQUIRED)
find_package(Qt${QT_VERSION_MAJOR} COMPONENTS Sql REQUIRED)#添加Sql组件


set(PROJECT_SOURCES
main.cpp
htmainwindow.cpp
htmainwindow.h
htmainwindow.ui
hovertreedb.h
hovertreedb.cpp
)

if(${QT_VERSION_MAJOR} GREATER_EQUAL 6)
qt_add_executable(HtDbHelper
MANUAL_FINALIZATION
${PROJECT_SOURCES}
)
# Define target properties for Android with Qt 6 as:
# set_property(TARGET HtDbHelper APPEND PROPERTY QT_ANDROID_PACKAGE_SOURCE_DIR
# ${CMAKE_CURRENT_SOURCE_DIR}/android)
# For more information, see https://doc.qt.io/qt-6/qt-add-executable.html#target-creation
else()
if(ANDROID)
add_library(HtDbHelper SHARED
${PROJECT_SOURCES}
)
# Define properties for Android with Qt 5 after find_package() calls as:
# set(ANDROID_PACKAGE_SOURCE_DIR "${CMAKE_CURRENT_SOURCE_DIR}/android")
else()
add_executable(HtDbHelper
${PROJECT_SOURCES}
)
endif()
endif()

#库的引用如下, by 何问起
target_link_libraries(HtDbHelper PRIVATE Qt${QT_VERSION_MAJOR}::Widgets)
target_link_libraries(HtDbHelper PRIVATE Qt${QT_VERSION_MAJOR}::Sql)#添加Sql库

set_target_properties(HtDbHelper PROPERTIES
MACOSX_BUNDLE_GUI_IDENTIFIER my.example.com
MACOSX_BUNDLE_BUNDLE_VERSION ${PROJECT_VERSION}
MACOSX_BUNDLE_SHORT_VERSION_STRING ${PROJECT_VERSION_MAJOR}.${PROJECT_VERSION_MINOR}
)

if(QT_VERSION_MAJOR EQUAL 6)
qt_finalize_executable(HtDbHelper)
endif()

如果是qmake构建系统,请参考:https://hovertree.com/h/bjag/53ryuc6t.htm
收藏 列表

评论:

导航