SQLite编译(How To Compile SQLite)

简介:

摘自:http://www.sqlite.org/howtocompile.html

 

Amalgamation Versus Individual Source Files与单个源文件合并

SQLite是符合ANSI-C规范的源码。必须编译成机器码方可使用。本文就是指导如何通过不同的方式对SQLite进行编译。

 

本文不会手把手的教你编译SQLitestep-by-steprecipe按部就班的菜谱)。鉴于开发平台的不同,很难提供一个统一的说明书。相反,本文仅仅是描述和解释SQLite编译的基本原理。

如下提供了一些例子,这些例子中包含的通用的编译命令,帮助应用程序开发人员快速开发自己的自定义编译程序

 

下文中提供了许多例子,这些例子包含了很多典型的编译选项命令。应用程序开发人员可以根据这些例子提供的指导,自定义编译程序。换言之,授人以鱼不如授人以渔(provides ideas and insights,not turnkey solutions

 

Alternative Source Code Formats  替代源代码格式

SQLite由一百多个C文件和脚本分散在不同的目录构成。SQLite由纯ANSI-C来实现,但是大部分的C语言源码文件都是由(auxiliaryC程序或者AWK,SED,TCL脚本生成或者转换,从而生成SQLite库。其中生成必须的C程序和转换成或者生成C语言源码本身就是一个复杂的过程。

 

为了省事,SQLite同样同乐一个单源码文件sqlite3.c。该文件可以构建完整的SQLite库。作为一个单源码文件,可以很轻易的包含在其他的应用程序当中。所有的代码生成或者转换都已经被实现,所以无需执行任何的脚本,无需任何的C程序的配置。整个库包含一个单独的转换单元,编译器能够提前优化,性能提升在在5%10%之间。感慨于此,强烈推荐采用单源码文件编译的方式。

The use of the amalgamation is recommendedfor all applications.

当然也可以通过独立的源码文件来构建SQLite库,但是不推荐。对于某些特殊的应用,从网页上下载的已经预编译的单源文件可能无法满足需要进行修改编译步骤的应用场景。因此,强烈推荐按照下文的步骤,定义一个新的单源码文件。就是说,即使项目需要从独立的源码文件开始构建SQLite库,还是希望能够将独立的源码文件构建成单源码文件,通过中间步骤的方式,来构建SQLite库(it is still recommended that an amalgamation source file be used asan intermediate step.

 

编译命令行接口Compiling The Command-Line Interface

 

sqlite3.c:SQLite单源码文件

sqlite3.hsqlite3.c的头文件以及定义了SQLiteC语言接口

shell.c:命令行接口程序。拥有main函数,循环等待用户的输入,然后提交用户的输入给SQLite数据库的引擎处理。





    本文转自fengyuzaitu 51CTO博客,原文链接:http://blog.51cto.com/fengyuzaitu/1950364 ,如需转载请自行联系原作者


相关文章
|
19天前
|
存储 SQL 数据库
数据库知识:了解SQLite或其他移动端数据库的使用
【10月更文挑战第22天】本文介绍了SQLite在移动应用开发中的应用,包括其优势、如何在Android中集成SQLite、基本的数据库操作(增删改查)、并发访问和事务处理等。通过示例代码,帮助开发者更好地理解和使用SQLite。此外,还提到了其他移动端数据库的选择。
21 8
|
30天前
|
Web App开发 SQL 数据库
使用 Python 解析火狐浏览器的 SQLite3 数据库
本文介绍如何使用 Python 解析火狐浏览器的 SQLite3 数据库,包括书签、历史记录和下载记录等。通过安装 Python 和 SQLite3,定位火狐数据库文件路径,编写 Python 脚本连接数据库并执行 SQL 查询,最终输出最近访问的网站历史记录。
|
1月前
|
存储 关系型数据库 数据库
轻量级数据库的利器:Python 及其内置 SQLite 简介
轻量级数据库的利器:Python 及其内置 SQLite 简介
|
1月前
|
应用服务中间件 PHP Apache
PbootCMS提示错误信息“未检测到您服务器环境的sqlite3数据库扩展...”
PbootCMS提示错误信息“未检测到您服务器环境的sqlite3数据库扩展...”
|
2月前
|
存储 API 数据库
QML使用Sqlite数据库存储ListModel数据
本文介绍了在QML中使用Sqlite数据库存储ListModel数据的方法,包括如何创建数据库、读取数据、动态添加和删除数据,以及如何在程序启动和退出时与数据库同步数据。
|
2月前
|
数据库 数据库管理
qt对sqlite数据库多线程的操作
本文总结了在Qt中进行SQLite数据库多线程操作时应注意的四个关键问题,包括数据库驱动加载、加锁、数据库的打开与关闭,以及QsqlQuery变量的使用。
135 1
|
29天前
|
存储 缓存 关系型数据库
sqlite 数据库 介绍
sqlite 数据库 介绍
35 0
|
3月前
|
人工智能 小程序 Java
【工具】轻松解锁SQLite数据库,一窥微信聊天记录小秘密
本文介绍了一款名为PyWxDump的开源工具,它可以获取微信账户信息、解密SQLite数据库以查看和备份聊天记录。此工具适用于已登录电脑版微信的用户,通过GitHub下载后简单几步即可操作。适合对数据恢复感兴趣的开发者,但请注意合法合规使用并尊重隐私。
478 2
【工具】轻松解锁SQLite数据库,一窥微信聊天记录小秘密
|
2月前
|
JSON NoSQL 数据库
和SQLite数据库对应的NoSQL数据库:TinyDB的详细使用(python3经典编程案例)
该文章详细介绍了TinyDB这一轻量级NoSQL数据库的使用方法,包括如何在Python3环境中安装、创建数据库、插入数据、查询、更新以及删除记录等操作,并提供了多个编程案例。
107 0
|
3月前
|
关系型数据库 Java MySQL
C#winform中使用SQLite数据库
C#winform中使用SQLite数据库
185 3
C#winform中使用SQLite数据库