What can be expected in v5? Lot of changes...
-
New Storage Engine
- New WAL (Write-Ahead Logging) for fast durability
- Database lock per collection
- MultiVersion Concurrency Control (Snapshots & Checkpoint)
- Multi concurrent
Stream
readers - Single async writer - No lock for reader
- Up to 32 indexes per collection
- Atomic multi-document transactions
- NET45 and NETStandard 2 support only (drop NET35/40)
- Single process only - optimazed for multi thread
-
New BsonExpression
- New super-fast tokenizer parser
- Clean syntax with optional use of
$
- Input/Output parameter support:
@name
- Simplified document notation
{ _id, name, year }
-
System Collections
- Support query over internal collection
$transactions
,$open_cursors
,$cache
,$dump
-
New QueryBuilder
- Fluent API for write queries
- Simple syntax using BsonExpressions
- Support OrderBy/GroupBy expressions
- Query optimization with Explain Plan
- Aggregate functions
-
New SQL-Like syntax
- Simple SQL syntax for any command
- Syntax near to SQL ANSI
- Support INSERT/UPDATE/DELETE/...
SELECT { _id, fullname: name.first + ' ' + name.last, age: 2018 - YEAR(birthday) }
FROM customers
WHERE name LIKE 'John%'
AND _id BETWEEN 1 AND 2000
INCLUDE orders
ORDER BY name
LIMIT 10
SELECT { city, count: COUNT($), high_pop: MAX(pop) }
FROM zip
GROUP BY city
- New Native UI - LiteDB.Studio
- WinForms app to manipulate database
- Based on SQL commands
- Show results in grid or as text
- Multi tabs, multi threads, multi transactions
.. but still...
- Embedded support
- Single database file
- Single DLL, no dependency and 100% C#
- 100% free open source
- 4 concurrent threads
- 4 collections
- 50,000 insert each thread/collection
v4 | v5 | |
---|---|---|
SSD disk | 3,274ms | 1,612ms |
HDD 7200 disk | 7,253ms | 1,659ms |
Roadmap: late in 2018 😄
LiteDB is a small, fast and lightweight NoSQL embedded database.
- Serverless NoSQL Document Store
- Simple API similar to MongoDB
- 100% C# code for .NET 4.5 / NETStandard 2.0 in a single DLL (less than 300kb)
- Thread safe and process safe
- ACID in document/operation level
- Data recovery after write failure (journal mode)
- Datafile encryption using DES (AES) cryptography
- Map your POCO classes to
BsonDocument
using attributes or fluent mapper API - Store files and stream data (like GridFS in MongoDB)
- Single data file storage (like SQLite)
- Index document fields for fast search (up to 16 indexes per collection)
- LINQ support for queries
- Shell command line - try this online version
- Pretty fast - compare results with SQLite here
- Open source and free for everyone - including commercial use
- Install from NuGet:
Install-Package LiteDB
- New
Expressions/Path
index/query support. See Expressions - Nested
Include
support - Optimized query execution (with explain plain debug)
- Fix concurrency problems
- Remove transaction and auto index creation
- Support for full scan search and LINQ search
- New shell commands: update fields based on expressions and select/transform documents
- See full changelog
Try LiteDB Web Shell. For security reasons, in the online version not all commands are available. Try the offline version for full feature tests.
Visit the Wiki for full documentation. For simplified chinese version, check here.
Download the source code or binary only in LiteDB Releases
A quick example for storing and searching documents:
// Create your POCO class
public class Customer
{
public int Id { get; set; }
public string Name { get; set; }
public int Age { get; set; }
public string[] Phones { get; set; }
public bool IsActive { get; set; }
}
// Open database (or create if doesn't exist)
using(var db = new LiteDatabase(@"MyData.db"))
{
// Get customer collection
var col = db.GetCollection<Customer>("customers");
// Create your new customer instance
var customer = new Customer
{
Name = "John Doe",
Phones = new string[] { "8000-0000", "9000-0000" },
Age = 39,
IsActive = true
};
// Create unique index in Name field
col.EnsureIndex(x => x.Name, true);
// Insert new customer document (Id will be auto-incremented)
col.Insert(customer);
// Update a document inside a collection
customer.Name = "Joana Doe";
col.Update(customer);
// Use LINQ to query documents (with no index)
var results = col.Find(x => x.Age > 20);
}
Using fluent mapper and cross document reference for more complex data models
// DbRef to cross references
public class Order
{
public ObjectId Id { get; set; }
public DateTime OrderDate { get; set; }
public Address ShippingAddress { get; set; }
public Customer Customer { get; set; }
public List<Product> Products { get; set; }
}
// Re-use mapper from global instance
var mapper = BsonMapper.Global;
// "Produts" and "Customer" are from other collections (not embedded document)
mapper.Entity<Order>()
.DbRef(x => x.Customer, "customers") // 1 to 1/0 reference
.DbRef(x => x.Products, "products") // 1 to Many reference
.Field(x => x.ShippingAddress, "addr"); // Embedded sub document
using(var db = new LiteDatabase("MyOrderDatafile.db"))
{
var orders = db.GetCollection<Order>("orders");
// When query Order, includes references
var query = orders
.Include(x => x.Customer)
.Include(x => x.Products) // 1 to many reference
.Find(x => x.OrderDate <= DateTime.Now);
// Each instance of Order will load Customer/Products references
foreach(var order in query)
{
var name = order.Customer.Name;
...
}
}
- Desktop/local small applications
- Application file format
- Small web applications
- One database per account/user data store
- Few concurrent write operations
- A GUI viewer tool: https://github.com/falahati/LiteDBViewer
- A GUI editor tool: https://github.com/JosefNemec/LiteDbExplorer
- Lucene.NET directory: https://github.com/sheryever/LiteDBDirectory
- LINQPad support: https://github.com/adospace/litedbpad
- F# Support: https://github.com/Zaid-Ajaj/LiteDB.FSharp
Change details for each release are documented in the release notes.
Copyright (c) 2017 - Maurício David
A special thanks to @negue and @szurgot helping with portable version and @lidanger for simplified chinese translation.