【QT+QGIS跨平台编译】之一:【sqlite+Qt跨平台编译】(一套代码、一套框架,跨平台编译)

文章目录

一、sqlite3介绍

SQLite是一款轻型的数据库,是遵守ACID的关系型数据库管理系统,它包含在一个相对小的C库中。它是D.RichardHipp建立的公有领域项目。它的设计目标是嵌入式的,而且已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了。它能够支持Windows/Linux/Unix等等主流的操作系统,同时能够跟很多程序语言相结合,比如 Tcl、C#、PHP、Java等,还有ODBC接口,同样比起Mysql、PostgreSQL这两款开源的世界著名数据库管理系统来讲,它的处理速度比他们都快。

复制代码
     SQLite特性:

①不需要一个单独的服务器进程或操作的系统( 无服务器 的)。

②SQLite 不需要配置,这意味着 不需要安装或管理 。

③ 一个完整的 SQLite 数据库是存储在一个 单一的跨平台的磁盘文件 。

④SQLite 是非常小的,是 轻量级 的,完全配置时小于 400KiB ,省略可选功能配置时小于 250KiB 。

⑤SQLite 是 自给自足 的,这意味着不需要任何外部的依赖。

⑥SQLite 事务是 完全兼容 ACID 的,允许从多个进程或线程安全访问。

⑦SQLite 支持 SQL92 ( SQL2 )标准的大多数查询语言的功能。

⑧SQLite 使用 ANSI-C 编写的,并提供了简单和易于使用的 API 。

⑨SQLite 可在 UNIX ( Linux, Mac OS-X, Android, iOS )和 Windows ( Win32, WinCE, WinRT )中运行,具备 跨平台 特性。


二、文件下载

sqlite网址:

https://www.sqlite.org/index.html

获取sqlite-autoconf-3390400.tar.gz、sqlite-dll-win64-x64-3390400.zip文件。


三、文件分析

解压缩sqlite-autoconf-3390400.tar.gz、sqlite-dll-win64-x64-3390400.zip文件。

在sqlite-autoconf-3390400文件夹,文件信息:

头文件与源文件:

解压缩sqlite-dll-win64-x64-3390400.zip

拷贝sqlite3.def


四、pro文件

配置头文件:

cpp 复制代码
#头文件
HEADERS +=  sqlite3.h \
            sqlite3ext.h

配置源文件:

cpp 复制代码
#源文件
SOURCES +=  sqlite3.c

导出的模块文件:

cpp 复制代码
win32 {
    DEF_FILE = sqlite3.def
}

设置预定义项:

cpp 复制代码
DEFINES -= UNICODE
DEFINES += SQLITE_ENABLE_COLUMN_METADATA SQLITE_ENABLE_PREUPDATE_HOOK
DEFINES += SQLITE_ENABLE_FTS3 SQLITE_ENABLE_FTS3_PARENTHESIS SQLITE_ENABLE_FTS5
DEFINES += SQLITE_ENABLE_RTREE SQLITE_ENABLE_JSON1 SQLITE_ENABLE_SESSION
DEFINES += SQLITE3_EXPORTS SQLITE_HAS_CODEC
DEFINES += CODEC_TYPE=CODEC_TYPE_AES128 SQLITE_CORE

win32 {
    DEFINES += _CRT_SECURE_NO_DEPRECATE _CRT_NONSTDC_NO_DEPRECATE
}

形成001.sqlite-3.39.4.pro文件:

cpp 复制代码
QT += core

TEMPLATE = lib
CONFIG += c++17

DESTDIR = ../QGIS
CONFIG(debug, debug|release){
    MOC_DIR = ../build-QGIS/sqlite3/Debug/moc
    RCC_DIR = ../build-QGIS/sqlite3/Debug/rcc
    UI_DIR = ../build-QGIS/sqlite3/Debug/ui
    OBJECTS_DIR = ../build-QGIS/sqlite3/Debug/obj
}else{
    MOC_DIR = ../build-QGIS/sqlite3/Release/moc
    RCC_DIR = ../build-QGIS/sqlite3/Release/rcc
    UI_DIR = ../build-QGIS/sqlite3/Release/ui
    OBJECTS_DIR = ../build-QGIS/sqlite3/Release/obj
}

CONFIG(debug, debug|release){
    TARGET = sqlite3d
}else{
    TARGET = sqlite3
}
DEFINES -= UNICODE
DEFINES += SQLITE_ENABLE_COLUMN_METADATA SQLITE_ENABLE_PREUPDATE_HOOK
DEFINES += SQLITE_ENABLE_FTS3 SQLITE_ENABLE_FTS3_PARENTHESIS SQLITE_ENABLE_FTS5
DEFINES += SQLITE_ENABLE_RTREE SQLITE_ENABLE_JSON1 SQLITE_ENABLE_SESSION
DEFINES += SQLITE3_EXPORTS SQLITE_HAS_CODEC
DEFINES += CODEC_TYPE=CODEC_TYPE_AES128 SQLITE_CORE

win32 {
    DEFINES += _CRT_SECURE_NO_DEPRECATE _CRT_NONSTDC_NO_DEPRECATE
}

# You can make your code fail to compile if it uses deprecated APIs.
# In order to do so, uncomment the following line.
#DEFINES += QT_DISABLE_DEPRECATED_BEFORE=0x060000    # disables all the APIs deprecated before Qt 6.0.0

#当前目录
INCLUDEPATH += ./

#头文件
HEADERS +=  sqlite3.h \
            sqlite3ext.h

#源文件
SOURCES +=  sqlite3.c

win32 {
    DEF_FILE = sqlite3.def
}

# Default rules for deployment.
#unix {
#    target.path = /usr/lib
#}
#!isEmpty(target.path): INSTALLS += target

五、编译实践

用QtCreator程序,打开001.sqlite-3.39.4.pro文件。

在windows下编译,形成:

在linux下编译,形成:

在macos下编译,形成:

相关推荐
玄同76540 分钟前
SQLite + LLM:大模型应用落地的轻量级数据存储方案
jvm·数据库·人工智能·python·语言模型·sqlite·知识图谱
ggabb3 小时前
中文的精确与意境,从来都不是英文能比肩的
sqlite
orange_tt16 小时前
Djiango配置Celery
数据库·sqlite
枝上棉蛮1 天前
GISBox vs QGIS:轻量化工具与开源平台的全方位选型指南
gis·免费·qgis·轻量化·gisbox·gis服务器
Ronin3051 天前
日志打印和实用 Helper 工具
数据库·sqlite·rabbitmq·文件操作·uuid生成
枝上棉蛮3 天前
2026年GIS软件精选:五款工具的专业性与实用性解析
arcgis·gis·qgis·超图·gisbox·地图数据处理·gis工具
码界奇点3 天前
基于Django的超市管理系统设计与实现
数据库·python·django·sqlite·毕业设计·源代码管理
JSON_L4 天前
使用 SQLite 创建数据库和表
数据库·sqlite·php
江湖有缘4 天前
基于华为openEuler部署Sqliteviz轻量级SQLite可视化工具
jvm·华为·sqlite
mahailiang5 天前
codeblocks+wxWidgets Projects中引用第三方库(sqlite3)
数据库·sqlite·wxwidgets·codeblocks