SQLite Version3.3.6源代码文件结构 -转载

简介: SQLite Version3.3.6源代码文件结构 Version 3.3.6源代码文件结构                                                ——整理:hustcat 2009-2-19 文件名称 大小byte 备注 API部分 main.

SQLite Version3.3.6源代码文件结构

Version 3.3.6源代码文件结构

                                               ——整理:hustcat 2009-2-19

文件名称

大小byte

备注

API部分

main.c

35414

SQLite Library的大部分接口

legacy.c

3734

sqlite3_exec的实现

table.c

5464

the sqlite3_get_table() and sqlite3_free_table()的实现,它们是sqlite3_exec的包装

preprare.c

17983

主要实现sqlite3_prepare()

 

 

 

分词器部分(Tokenizer)

tokenize.c

14495

分词器的实现

语法分析器部分(Parser)

parser.c

116917

分析器的实现,由Lemon实现

parser.h

6847

分析器内部定义的关键字

 

 

 

代码生成器部分(Code Generator)

update.c

23878

处理UPDATTE语句

delete.c

21978

处理DELETE语句

insert.c

62026

处理INSERT语句

trigger.c

29065

处理TRIGGER语句

attach.c

15941

处理ATTACHT DEATTACH语句

select.c

112084

处理SELECT语句

where.c

75826

处理WHERE语句

vacuum.c

11005

处理VACUUM语句

pragma.c

34289

处理PRAGMA命令

expr.c

73963

处理SQL语句中的表达式

auth.c

7496

主要实现sqlite3_set_authorizer()

analyze.c

13149

实现ANALYZE命令

alter.c

18414

实现ALTER TABLE功能

build.c

104052

处理以下语法:

CREATE TABLE

DROP TABLE

CREATE INDEX

DROP INDEX

creating ID lists

BEGIN TRANSACTION

COMMIT

ROLLBACK

func.c

34335

实现SQL语句的函数语句

date.c

24031

与日期和时间转换有关的函数

虚拟机部分(Virtual Machine)

vdbeapi.c

23300

虚拟机提供上层模块调用的API实现部分

vdbe.c

143552

虚拟机的主要实现部分

vdbe.h

5309

定义了VDBE的接口,VdbeOp结构体(代表一条指令)

vdbeaux.c

58741

Vdbe.h的接口的实现

vdbeInt.h

17595

Vdbe.c的私有头文件,定义了VDBE常用的数据结构:

Cursor——虚拟机中使用的游标

Mem——vdbe在内部把所有的SQL值当作一个Mem数据结构来处理

Vdbe——虚拟机数据结构

vdbemem.c

26375

操作”Mem”数据结构的函数

vdbefifo.c

2927

 

 

 

 

B-Tree部分

btree.h

5260

头文件,定义了B-tree提供的操作接口

 

btree.c

215570

B-Tree部分的主要实现,并定义了以下数据结构:

Btree——Btree handler

BtCursor——使用的游标

BtLock——锁

BtShared——包含了一个打开的数据库的所有信息

MemPage——文件在内存存放在该数据结构中

CellInfo

 

 

 

Pager部分

pager.h

4161

定义sqlite page cache子系统提供的接口

pager.c

127490

Pager模块的主要实现,并定义了以下数据结构:

PgHdr——每一个内存中的页面的页面头

Pager——该模块中最重要的数据结构

PgHistory

 

 

 

OS Interface部分

os.h

18355

定义了为上层模块提供的操作函数,并定义了以下数据结构:

OsFile——描述一个文件

IoMethod——OsFile所支持的操作函数(对所有架构都适用的OS Interface

os.c

2866

IoMethod中的函数的包装

os_win.c

42975

Windows平台下的OS Interface

os_unix.c

60831

Unix平台下的OS Interface

os_os2.c

28451

OS2平台下的OS Interface

 

 

 

其它部分

utf.c

20891

UTF编码有关的函数

util.c

43575

一些实用函数,比如:

sqlite3Malloc()sqlite3FreeX()

sqlite3.h

63873

SQLite的头文件,定义了提供给应用使用的API和数据结构。

sqliteInt.h

78886

定义了SQLite内部使用的接口和数据结构

printf.c

29556

主要实现与printf有关的函数

random.c

3078

随机数生成

hash.c

11896

SQLite使用的hash

hash.h

4033

Hash 表头文件

目录
相关文章
|
28天前
|
监控 关系型数据库 数据库
OceanBase数据库常见问题之文件存在但是数据库提示文件不存在如何解决
OceanBase 是一款由阿里巴巴集团研发的企业级分布式关系型数据库,它具有高可用、高性能、可水平扩展等特点。以下是OceanBase 数据库使用过程中可能遇到的一些常见问题及其解答的汇总,以帮助用户更好地理解和使用这款数据库产品。
|
29天前
|
API 数据库 C语言
【C/C++ 数据库 sqlite3】SQLite C语言API返回值深入解析
【C/C++ 数据库 sqlite3】SQLite C语言API返回值深入解析
169 0
|
1月前
|
SQL Java 数据库连接
从来没想到我们会扒拉nohup文件去找我们想要的数据,然后往数据库中添加。。。...
从来没想到我们会扒拉nohup文件去找我们想要的数据,然后往数据库中添加。。。...
17 0
|
2月前
|
数据库
Google Earth Engine(GEE)——全球树木异体测量和树冠结构(Tallo)数据库
Google Earth Engine(GEE)——全球树木异体测量和树冠结构(Tallo)数据库
21 1
|
2月前
|
存储 监控 安全
内网屏幕监控软件的数据存储与管理:使用SQLite数据库保存监控记录和配置信息
在当今数字化时代,安全和监控在企业和组织中变得至关重要。内网屏幕监控软件作为一种关键工具,帮助组织监视员工的活动并确保信息安全。这种软件不仅需要高效地记录和管理监控数据,还需要能够方便地进行配置和调整。本文将讨论如何使用SQLite数据库来保存监控记录和配置信息,并介绍如何通过自动化机制将监控到的数据提交到指定网站。
162 2
|
1天前
|
NoSQL MongoDB 数据库
MongoDB数据恢复—MongoDB数据库文件被破坏的数据恢复案例
服务器数据恢复环境: 一台Windows Server操作系统服务器,服务器上部署MongoDB数据库。 MongoDB数据库故障&检测: 工作人员在未关闭MongoDB数据库服务的情况下,将数据库文件拷贝到其他分区。拷贝完成后将原MongoDB数据库所在分区进行了格式化操作,然后将数据库文件拷回原分区,重新启动MongoDB服务,服务无法启动。
|
7天前
|
存储 关系型数据库 MySQL
如何处理爬取到的数据,例如存储到数据库或文件中?
处理爬取的数据,可存储为txt、csv(适合表格数据)或json(适合结构化数据)文件。若需存储大量数据并执行复杂查询,可选择关系型(如MySQL)或非关系型(如MongoDB)数据库。以MySQL为例,需安装数据库和Python的pymysql库,创建数据库和表,然后编写Python代码进行数据操作。选择存储方式应考虑数据类型、数量及后续处理需求。
14 1
|
11天前
|
SQL 关系型数据库 数据库
Python中SQLite数据库操作详解:利用sqlite3模块
【4月更文挑战第13天】在Python编程中,SQLite数据库是一个轻量级的关系型数据库管理系统,它包含在一个单一的文件内,不需要一个单独的服务器进程或操作系统级别的配置。由于其简单易用和高效性,SQLite经常作为应用程序的本地数据库解决方案。Python的内置sqlite3模块提供了与SQLite数据库交互的接口,使得在Python中操作SQLite数据库变得非常容易。
|
13天前
|
存储 SQL Oracle
【Oracle】玩转Oracle数据库(二):体系结构、存储结构与各类参数
【Oracle】玩转Oracle数据库(二):体系结构、存储结构与各类参数
35 7
|
16天前
|
关系型数据库 MySQL 数据库连接
Python+SQLite数据库实现服务端高并发写入
Python中使用SQLite内存模式实现高并发写入:创建内存数据库连接,建立表格,通过多线程并发写入数据。虽然能避免数据竞争,但由于SQLite内存模式采用锁机制,可能在高并发时引发性能瓶颈。若需更高性能,可选择MySQL或PostgreSQL。
22 0

热门文章

最新文章