SQLite
维基百科,自由的百科全书
SQLite |
|
---|---|
开发者 | D. Richard Hipp |
最新版 | 3.5.8 / 2008年4月16日 |
操作系统 | 跨平台 |
类型 | 开发库 |
许可协议 | 公有领域 |
网站 | SQLite |
SQLite是遵守ACID的關聯式資料庫管理系统,它包含在一个相对小的C库中。它是D.RichardHipp建立的公有领域项目。
不像常见的客户-服务器范例,SQLite引擎不是个程序与之通信的独立进程,而是连接到程序中成为它的一个主要部分。所以主要的通信协议是在编程语言内的直接API调用。这在消耗总量、延迟时间和整体简单性上有积极的作用。整个数据库(定义、表、索引和数据本身)都在宿主主机上存储在一个单一的文件中。它的简单的设计是通过在开始一个事务的时候锁定整个数据文件而完成的。
目录 |
[编辑] 特征
库实现了多数的SQL-92标准,包括事务,就是代表原子性、一致性、隔離性和持久性的(ACID),触发器和多数的复杂查询。不进行类型检查。你可以把字符串插入到整数列中。例如,某些用户发现这是使数据库更加有用的创新,特别是与无类型的脚本语言一起使用的时候。其他用户认为这是主要的缺点。
多个进程或线程可以访问同一个数据而没有问题。可以并行的满足多个读访问。只有在其他访问当前不被服务的时候才能满足写访问;否则写访问失败并带有一个错误代码(也可以在可配置的超时过期之后自动的重试)。
提供了叫做sqlite的一个独立程序用来查询和管理SQLite数据库文件。 它也充当写使用SQLite库的应用的一个例子。
[编辑] 语言绑定
可以从C/C++程序中使用这个库,还可以获得对Tcl和一些其他脚本语言的绑定。
在CPAN的DBD::SQLite上有一个Perl的DBI/DBD模块,它不是到SQLite的接口,而是包括整个SQLite数据库引擎在其中并不需要任何额外的软件。
还有一个Python模块叫做PySQLite。
PHP从PHP5.0开始包含了SQLite,但是自5.1版之後開始成為一個延伸函式庫。SQLite能与PHP4一起工作但不包含在其中。
Rails2.0.3将缺省的数据库配置改为了SQLite 3
[编辑] SQLite管理客户端
SQLite亦可以作为桌面数据库使用,以下为第三方SQLite的GUI软件。例如,
- SQLiteMan,使用QT开发的一个SQLite客户端,支持多语言、跨平台。SQLiteMan
- SQLite Manager, 以 火狐浏览器的扩展形式提供的SQLite客户端。
- SQLite Database Browser, a graphical client to access SQLite databases
- SqlPro SQL Client, another graphical client to work with SQLite databases
[编辑] 參見
- 关系数据库列表
- 关系数据库比较
[编辑] 外部链接
- SQLite 主页
- pysqlite - A Python Wrapper.
- DBD::SQLite - CPAN 上的 Perl 模块。
- Sqlite-ruby - Ruby 语言接口。
- SQLiteManager - 管理 SQLite 数据库的多语言的 PHP4 写的 web 工具。
- SQLite Developer - SQLite 可视化数据库管理器。
- SQLiteBrowser - 視窗介面 SQLite 資料庫瀏覽器
- SQLite ODBC 驱动程序
- SQLite C++ 包装器
- Visual SQLite - SQLite 的 Windows 下 GUI 界面。
- SQLiteSpy - Win32 GUI with Unicode support, Freeware
- SQLite Administrator (english, german, french, portugues)
- SQLite.NET 2.0 - An ADO.NET 2.0 provider for SQLite
- Using SQLite Database with OpenOffice.org (via ODBC or *sqlite-sdbc-driver)
- A tutorial to SQLite3
- Interview with Richard Hipp
数据库管理系统(DBMS) ( | |
概念 |
|
Objects |
SQL |
数据库管理系统的实施 | |
实施类型 |
|
数据库产品 |
数据库成分 |