新版SQLite源码下载与编译
liebian365 2024-11-19 06:27 22 浏览 0 评论
概述
“最新版GDAL源码下载 ”一文中,我们为大家分享了最新版本的GDAL源码,而GDAL是需要依赖PROJ投影转换库的。
因此,在最新版投影转换工具PROJ源码 ”一文中,我们又为大家分享了PROJ的源码,如果你对PROJ源码进行编译,会发现它会需要SQLite的支持。
这里,我们再为大家分享SQLite的源码下载与编译的方法,你可以通过关注微信公众号“水经注GIS”并回复“SQLite”获取最新版本的SQLite源码与基于VS2015的编译工程文件。
什么是SQLite?
SQLite是一个进程库,实现了一个自包含的,无服务器,零配置及事务性的SQL数据库引擎。
SQLite的源代码是公开的,因此可以免费用于任何目的,无论是否是商业目的。
SQLite是世界上部署最广泛的数据库,其应用程序数量超出我们的想象,其中包括Adobe公司、Airbus公司、FaceBook、微软、苹果和谷歌等世界知名企业,SQLite数据库文件也是美国国会图书馆推荐的存储格式。
SQLite是嵌入式SQL数据库引擎,与大多数其他SQL数据库不同,SQLite没有单独的服务器进程。
SQLite直接读取和写入普通磁盘文件,具有多个表、索引、触发器和视图的完整SQL数据库包含在单个磁盘文件中。
数据库文件格式是跨平台的,因此可以在32位和64位系统之间或在big-endian和 little-endian 体系结构之间自由复制数据库,这些功能使SQLite成为应用程序文件格式的流行选择。
SQLite是一个紧凑的库,启用所有功能后,库大小可以小于600KB,具体取决于目标平台和编译器优化的设置。
SQLite在内存越大的情况下运行速度就越快,即使在低内存环境下,性能通常也相当不错,甚至可能会比直接通过系统I/O读取更快。
如何下载最新版SQLite源码
最新版本的SQLite源码可以到官方网站下载,在官方网站的第一项下载链接即为源码,如下图所示。
SQLite官网
另外,还需要下载模块定义文件sqlite3.def,否则无法生成sqlite3.lib库,如下图所示。
下载预编译文件
为了便于使用,可以把源码和预编译文件的32位与64位版本都下载下来,如下图所示。
源码文件压缩包
将文件进行解压,根据实际需要,预编译文件可以选择32位或64位版本,最后将源码文件汇总到一个目录中备用,如下图所示。
以上准备工作就绪之后,接下来就可以对源码进行编辑了。
如何基于VS2015编译SQLite源码
我们基于VS2015对SQLite源码进行编译,如果你还没有任何编译工具,请参阅“Visual Studio 2015 安装教程(附安装包)”一文部署安装编译环境。
在VS2015中新建一个名为“sqlite3”的Win32项目,如下图所示。
点击下一步继续,然后在应用程序设置中选择“DLL”和“空项目”,如下图所示。
项目新建完成后,将之前准备的源码文件复制到工程目录,如下图所示。
通过添加现有项功能,将头文件sqlite.h和sqlite3ext.h添加到工程中,如下图所示。
另外,也需要将shell.c、sqlite3.c和sqlite3.def添加到源文件中,如下图所示。
现在如果直接编译工程,则不会生成sqlite3.lib库文件,因此需要在项目属性中设置sqlite3.def模块定义文件,如下图所示。
现在将源码进行编辑之后,会生成许多错误提示:
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3_column_database_name
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3_column_database_name16
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3_column_origin_name
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3_column_origin_name16
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3_column_table_name
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3_column_table_name16
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3_deserialize
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3_fts3_may_be_corrupt
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3_fts5_may_be_corrupt
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3_preupdate_count
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3_preupdate_depth
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3_preupdate_hook
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3_preupdate_new
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3_preupdate_old
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3_rtree_geometry_callback
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3_rtree_query_callback
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3_serialize
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3changegroup_add
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3changegroup_add_strm
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3changegroup_delete
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3changegroup_new
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3changegroup_output
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3changegroup_output_strm
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3changeset_apply
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3changeset_apply_strm
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3changeset_apply_v2
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3changeset_apply_v2_strm
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3changeset_concat
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3changeset_concat_strm
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3changeset_conflict
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3changeset_finalize
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3changeset_fk_conflicts
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3changeset_invert
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3changeset_invert_strm
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3changeset_new
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3changeset_next
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3changeset_old
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3changeset_op
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3changeset_pk
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3changeset_start
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3changeset_start_strm
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3changeset_start_v2
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3changeset_start_v2_strm
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3rebaser_configure
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3rebaser_create
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3rebaser_delete
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3rebaser_rebase
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3rebaser_rebase_strm
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3session_attach
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3session_changeset
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3session_changeset_strm
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3session_config
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3session_create
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3session_delete
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3session_diff
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3session_enable
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3session_indirect
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3session_isempty
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3session_memory_used
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3session_patchset
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3session_patchset_strm
1>sqlite3.def : error LNK2001: 无法解析的外部符号 sqlite3session_table_filter
生成错误的原因,是因为在sqlite3.def中定义的函数在源码中默认没有导出,需要在工程属性中添加以下预处理定义,如下所示。
SQLITE_CORE
SQLITE_EXPORTS
SQLITE_ENABLE_FTS3
SQLITE_ENABLE_FTS5
SQLITE_ENABLE_RTREE
SQLITE_ENABLE_COLUMN_METADATA
SQLITE_ENABLE_SESSION
SQLITE_ENABLE_PREUPDATE_HOOK
SQLITE_ENABLE_DESERIALIZE
只要上述配置正确,无论是在Debug还是Release版本下都可以编译成功,如下图所示。
编译成功后,就可以在源码工程的Debug或Release目录中找到sqlite3.dll和sqlite3.lib文件,如下图所示。
现在,我们将下载的源码文件压缩包,编译成功的工程源码整理到了一个目录中,如下图所示。
为了方便分享,我们将上述整理好的文件打包上传到了百度网盘中,请通过关注微信公众号“水经注GIS”,然后在后台回复“SQLite”可获取下载地址。
总结
SQLite代码库由一支全职从事SQLite工作的国际开发人员团队支持,以持续扩展SQLite的功能并增强其可靠性和性能,同时保持与已发布的接口规范,以及SQL语法和数据库文件格式的向后兼容性。
最后,如果你在SQLite源码编译过程中遇到任何难题,请通过关注公众号“水经注GIS”并在后台留言告诉我们,我们将竭尽所能地为你提供帮助,从而将我们“为用户提供丰富的地图数据与专业的GIS服务”之宗旨落到实处!
相关推荐
- 4万多吨豪华游轮遇险 竟是因为这个原因……
-
(观察者网讯)4.7万吨豪华游轮搁浅,竟是因为油量太低?据观察者网此前报道,挪威游轮“维京天空”号上周六(23日)在挪威近海发生引擎故障搁浅。船上载有1300多人,其中28人受伤住院。经过数天的调...
- “菜鸟黑客”必用兵器之“渗透测试篇二”
-
"菜鸟黑客"必用兵器之"渗透测试篇二"上篇文章主要针对伙伴们对"渗透测试"应该如何学习?"渗透测试"的基本流程?本篇文章继续上次的分享,接着介绍一下黑客们常用的渗透测试工具有哪些?以及用实验环境让大家...
- 科幻春晚丨《震动羽翼说“Hello”》两万年星间飞行,探测器对地球的最终告白
-
作者|藤井太洋译者|祝力新【编者按】2021年科幻春晚的最后一篇小说,来自大家喜爱的日本科幻作家藤井太洋。小说将视角放在一颗太空探测器上,延续了他一贯的浪漫风格。...
- 麦子陪你做作业(二):KEGG通路数据库的正确打开姿势
-
作者:麦子KEGG是通路数据库中最庞大的,涵盖基因组网络信息,主要注释基因的功能和调控关系。当我们选到了合适的候选分子,单变量研究也已做完,接着研究机制的时便可使用到它。你需要了解你的分子目前已有哪些...
- 知存科技王绍迪:突破存储墙瓶颈,详解存算一体架构优势
-
智东西(公众号:zhidxcom)编辑|韦世玮智东西6月5日消息,近日,在落幕不久的GTIC2021嵌入式AI创新峰会上,知存科技CEO王绍迪博士以《存算一体AI芯片:AIoT设备的算力新选择》...
- 每日新闻播报(September 14)_每日新闻播报英文
-
AnOscarstatuestandscoveredwithplasticduringpreparationsleadinguptothe87thAcademyAward...
- 香港新巴城巴开放实时到站数据 供科技界研发使用
-
中新网3月22日电据香港《明报》报道,香港特区政府致力推动智慧城市,鼓励公私营机构开放数据,以便科技界研发使用。香港运输署21日与新巴及城巴(两巴)公司签署谅解备忘录,两巴将于2019年第3季度,开...
- 5款不容错过的APP: Red Bull Alert,Flipagram,WifiMapper
-
本周有不少非常出色的app推出,鸵鸟电台做了一个小合集。亮相本周榜单的有WifiMapper's安卓版的app,其中包含了RedBull的一款新型闹钟,还有一款可爱的怪物主题益智游戏。一起来看看我...
- Qt动画效果展示_qt显示图片
-
今天在这篇博文中,主要实践Qt动画,做一个实例来讲解Qt动画使用,其界面如下图所示(由于没有录制为gif动画图片,所以请各位下载查看效果):该程序使用应用程序单窗口,主窗口继承于QMainWindow...
- 如何从0到1设计实现一门自己的脚本语言
-
作者:dong...
- 三年级语文上册 仿写句子 需要的直接下载打印吧
-
描写秋天的好句好段1.秋天来了,山野变成了美丽的图画。苹果露出红红的脸庞,梨树挂起金黄的灯笼,高粱举起了燃烧的火把。大雁在天空一会儿写“人”字,一会儿写“一”字。2.花园里,菊花争奇斗艳,红的似火,粉...
- C++|那些一看就很简洁、优雅、经典的小代码段
-
目录0等概率随机洗牌:1大小写转换2字符串复制...
- 二年级上册语文必考句子仿写,家长打印,孩子照着练
-
二年级上册语文必考句子仿写,家长打印,孩子照着练。具体如下:...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- wireshark怎么抓包 (75)
- qt sleep (64)
- cs1.6指令代码大全 (55)
- factory-method (60)
- sqlite3_bind_blob (52)
- hibernate update (63)
- c++ base64 (70)
- nc 命令 (52)
- wm_close (51)
- epollin (51)
- sqlca.sqlcode (57)
- lua ipairs (60)
- tv_usec (64)
- 命令行进入文件夹 (53)
- postgresql array (57)
- statfs函数 (57)
- .project文件 (54)
- lua require (56)
- for_each (67)
- c#工厂模式 (57)
- wxsqlite3 (66)
- dmesg -c (58)
- fopen参数 (53)
- tar -zxvf -c (55)
- 速递查询 (52)