SQLite
From Wikipedia, the free encyclopedia
SQLiteは、リチャード・ヒップ(通称: Hipp)により開発された、パブリックドメインの軽量なRDBMSである。クライアントサーバモデルと異なり、単一ライブラリファイルのAPIを利用する。
|
| |
|
| |
| 開発元 | リチャード・ヒップ |
|---|---|
| 初版 | 2000年8月17日 |
| 最新版 |
3.52.0[1] |
| リポジトリ | |
| プログラミング 言語 | C |
| 対応OS | クロスプラットフォーム |
| 種別 | 関係データベース管理システム |
| ライセンス | パブリックドメイン |
| 公式サイト |
sqlite |
概要
SQLiteは、「エスキューライト[2]/エスキューエライト[3]」と発音する。Hippは「エスキューエルアイト(/ˌɛsˌkjuːˌɛlˈaɪt/)[4][5][6]」と発音している。
SQLiteとは(公式HPより翻訳)[7]
SQLiteは、小型で高速、自己完結型、高信頼性、フル機能を備えたSQLデータベースエンジンを実装したC言語ライブラリです。SQLiteは世界で最も利用されているデータベースエンジンです。SQLiteはすべての携帯電話とほとんどのコンピュータに組み込まれており、人々が毎日使用する無数のアプリケーションにもバンドルされています。
SQLiteを組み込んだアプリケーションの一例
- AndroidのデータストレージAPI
- Mozilla Firefox(142.x現在)[8]
- Mozilla Thunderbird(142.x現在)[9]
特徴
ストレージに互換性があれば、データベースファイルはWindows/Linux等で共用可能。一時的な利用ならば、インメモリデータベースを割り当てることも可能。ストレージまでプロセス間通信などを用いず、直接ネイティブコードで実行することで、トランザクション処理におけるレイテンシをある程度削減することに成功している(トランザクション処理時、ストレージはロックされ、セッションはキャッシュを有効利用して高速にデータアクセスする)。動的リンク/静的リンクに対応しており、静的リンクで実行ファイルを生成しても700KB程度(3.50.x現在)のフットプリントで、充実したSQLステートメントと束縛のないデータ型を利用可能である。
ウィキブックスも参照のこと。
開発と展開
SQLiteのコードは同じくHippが開発したFossilでホストされている。Fossilは、非リレーショナルデータベース形式のSQLiteをローカルキャッシュとして使用し、SQLiteのSQLを実装言語として使用する分散バージョン管理システムである。
SQLiteはパブリックドメインとして著作権を放棄する一方、「オープンコントリビューション」ではないため、誰でも開発に参加することはできない。公式ウェブサイトには「このプロジェクトは、貢献をパブリックドメインに捧げる宣誓供述書を提出していない人からのパッチは受け付けない」と記載するとともに、プロジェクト創設者らは、行動規範の代わりに聖ベネディクトの戒律に基づく倫理規定を採用している[10]。
SQLiteの配布物には、 sqlite3 と呼ばれるスタンドアロンのコマンドライン シェルプログラムが付属している[11]。このプログラムを使用して、データベースの作成、テーブルの定義、行の挿入と変更、クエリの実行、SQLiteデータベースファイルの管理を行うことができる。また、SQLiteライブラリを使用するアプリケーションを作成するためのサンプルとしても役立つよう設計されている。
歴史
Hippは2000年春、アメリカ海軍との契約に基づき勤務していたジェネラル・ダイナミクス社に在籍中、SQLiteを設計した。彼はミサイル駆逐艦のダメージコントロールシステムに使用されるソフトウェアを設計しており、これは当初HP-UXとInformixデータベースをバックエンドとして利用していた。SQLiteはTcl拡張機能として開発が始まった。
2000年8月、SQLiteのバージョン1.0がリリースされた。ストレージはgdbm(GNU Database Manager)をベースにしていた。
2001年9月、SQLite 2.0はgdbmをカスタムBツリー実装に置き換え、トランザクション機能を追加した。
2001年から2002年頃、最初期の大規模な開発と利用はモトローラの携帯電話であった。その後ノキアのSymbianへの採用が決まって大口顧客になると、携帯電話メーカーからの支持も高まった[12]。
2004年6月、AOLの資金提供を受けて[13]、SQLite 3.0では国際化、マニフェスト型付け、およびその他の主要な改良点を追加した(AOLは当時プロバイダへの加入を促すCD-ROMを配布しており、そのプログラムにSQLiteを組み込んでいた[14])。
2007年12月、Mozilla FoundationやSymbianと共同でSQLiteコンソーシアムを設立した[15]。同時期にAndroidの標準ライブラリに採用されたことや、同じくiPhoneでも採用されるなどしたことで、スマートフォンの爆発的な普及とともにSQLiteも広がった[16]。
2011年、HippはSQLiteにNoSQLインターフェースを追加する計画を発表し、ドキュメント指向データベース向けに設計されたSQLの機能的スーパーセットであるUnQLも発表した[17]。
テストと信頼性
SQLiteは、各リリースの前に自動回帰テストを実施しており、その一環として200万以上のテストが実施されている。SQLiteライブラリのソースコードは約156,000行あるが、すべてのテスト用コードを合わせると9,200万行になる。SQLiteのテストでは、ライブラリの機能性をテストするだけでなく、突然の停電による電源喪失やI/Oエラーなどの様々な例外的なシナリオをシミュレートしており、データベース更新中に電源を遮断してもデータに破損が無いことが証明できることを目指している[18]。2009年8月10日のSQLite 3.6.17リリース以降、SQLiteリリースはコードカバレッジの構成要素の一つであるブランチテストカバレッジが100%となっている。
SQLiteには、オリジナルのパブリックドメインTCLテスト、独自のC言語TH3テストスイート、SQLiteを他のSQLデータベースと比較するSQLロジックテスト、そして独自のファジングエンジンdbsqlfuzzの4つの異なるテストハーネスがある。公式サイトでは、こうした徹底的なテストを行うことによってミッションクリティカルな利用にも耐え得るとしている[19]。実際SQLiteはデータセットの長期保存に推奨される4つの形式の1つとしてアメリカ議会図書館が使用を承認している[20]。