Skip to content

100% Native C# Key Value Store High Performance NoSQL Database with ACID Transaction

License

Notifications You must be signed in to change notification settings

Polyhaze/SharpDB

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

28 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

SharpDB

SharpDB is C# based High Performance Key Value NoSQL Database with ACID Transaction. SharpDB is using Multiversion concurrency control to achieve transactions. Because of using MVCC SharpDB is very fast in doing transaction (the downside is that SharpDB using a lof of space).

For network protocl SharpDB is using NetMQ which is C# port of ZeroMQ, which means SharpDB is using very fast on the network as well.

Installation

Packages of SharpDB is still not available, so download the code code and compile.

After compiling run the following command to run the server:

SharpDB.Server.exe run -name:test -port:5555

You can change the name and port fields as you like. File called name.sdb will be created as the database file.

You can also run the database as a service with the following commands (must run as administrator)

SharpDB.Server.exe install -name:test -port:5555
SharpDB.Server.exe start

Using

To use SharpDB from your application include the SharpDB.Driver assembly. Following is small example of using the SharpDB driver:

	[Test]
	public void UpdateGet()
	{
		using (SharpDBClient client = new SharpDBClient("tcp://127.0.0.1:5555"))
		{
			using (SharpDBConnection connection = client.GetConnection())
			{
				Account newAccount = new Account();
				newAccount.Name = "Hello";
				newAccount.Id = 1;

				connection.Update(newAccount);

				Account storedAccount = connection.Get<Account>(1);

				Assert.AreEqual("Hello", storedAccount.Name);
			}
		}
	}

and the account class:

public class Account
{
	public int Id { get; set; }

	public string Name { get; set; }
}

About

100% Native C# Key Value Store High Performance NoSQL Database with ACID Transaction

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published