Architecture

就像编译器一样,结构分为前端、虚拟机、后端
性能和限制(limitations)
使用B树来做indexes,用B+树来做table。和其他数据库一样
由于不需要鉴权、网络访问,所以对于select
,insert
,update
操作比其他数据库要快一些。
如果数据库过大、查询语句太过复杂的话,SQLite性能不如其他数据库。Oracle或PostgreSQL计算出很多可行的query plan,然后选择一个最优的。SQLite没有这个功能。
一般来说,两个维度限制了SQLite的应用。
- 并发。 一般来说,SQLite中的锁持续几毫秒。如果数据库有很多连接,且是时间敏感的,最好不要用。
- 网络。 SQLite可以通过网络文件系统共享,但是很多NFS的实现有很多bug,从而导致了文件锁的不正常工作,进而使得数据不一致等情况。
有一些功能SQlite还没有实现。
- 完整的触发器(trigger)支持。 比如for each statment
- 完整的alter table
支持。 只支持RENAME TABLE
和ADD COLUMN
。其他的ALERT TABLE
操作,如DROP COLUMN
,ALTER COLUMN
,ADD CONSTRAINT
不支持
- RIGHT
和FULL OUTER JOIN
。
- 可以更新的views。 SQLite中View是只读的。
- Windowing函数。SQLite兼容ANSI SQL 92,不兼容ANSI SQL 99。不支持RANK()
,ROW_NUMBER
等等
- GRANT
和REVOKE