跳至內容

LevelDB

維基百科,自由的百科全書
LevelDB
開發者Google
首次發布2012年5月,​12年前​(2012-05
當前版本1.23[1]在維基數據編輯(2021年2月23日,3年前)
原始碼庫 編輯維基數據鏈接
程式語言C++
作業系統跨平台
類型嵌入資料庫編程庫
許可協議BSD許可證
網站github.com/google/leveldb 編輯維基數據

LevelDB是一個由Google公司所研發的鍵-值存儲嵌入式資料庫管理系統編程庫,[2]開源BSD許可證發佈。[3]

特徵

[編輯]

例子

[編輯]

儲存鍵/值對,和查詢鍵的值:

#include "leveldb/db.h"
#include <iostream>

using namespace std;

int main(){
  leveldb::DB *db;
  leveldb::Options options;

  options.create_if_missing = true;

  // 開啟數據庫
  leveldb::DB::Open(options, "/tmp/testdb", &db);

  // 鍵 = MyKey29,值 = "Hello World!"
  string key = "MyKey29", value = "Hello World!", result;

  // 儲存 鍵/值對
  db->Put(leveldb::WriteOptions(), key, value);

  // 查詢 MyKey29 鍵的值
  db->Get(leveldb::ReadOptions(), key, &result);

  // 輸出值到屏幕
  cout << "result = " << result << endl;

  // 關閉數據庫
  delete db;

  return 0;
}

執行結果

[編輯]

(LevelDB安裝目錄為:leveldb-read-only)[6]

% g++ test.cc -Ileveldb-read-only/include -Lleveldb-read-only -lleveldb -lpthread
% ./a.out 
result = Hello World!

RocksDB

[編輯]

2013年Facebook基於LevelDB開發出RocksDB,特別針對伺服器負載而優化。[7]

語言的綁定

[編輯]

參見

[編輯]

參考文獻

[編輯]
  1. ^ 1.0 1.1 Release 1.23. 2021年2月23日 [2021年3月13日]. 
  2. ^ leveldb實現解析 (PDF). [2017-09-05]. (原始內容存檔 (PDF)於2012-01-31). 
  3. ^ LevelDB: A Fast Persistent Key-Value Store. [2011-08-07]. (原始內容存檔於2016-03-26). 
  4. ^ LevelDB Benchmarks. [2011-08-07]. (原始內容存檔於2011-08-20). 
  5. ^ A fast compressor/decompressor. [2011-07-30]. (原始內容存檔於2015-08-22). 
  6. ^ Source Checkout - LevelDB. [2011-08-06]. (原始內容存檔於2015-03-18). 
  7. ^ RocksDB. [2014-01-25]. (原始內容存檔於2021-02-05). 

外部連結

[編輯]