using NMemory.StoredProcedures;
using System.Collections.Concurrent;
public static void Main()
MyDatabase myDatabase = new MyDatabase();
myDatabase.Groups.Insert(new Group() { Id = 1, Name = "Group_1"});
myDatabase.Groups.Insert(new Group() { Id = 2, Name = "Group_2"});
var procedure = new SharedStoredProcedure<MyDatabase, Group>(
d => d.Groups.Where(g => g.Id > 1));
var result = procedure.Execute(myDatabase, null).ToList();
FiddleHelper.WriteTable("All Members", result);
public class MyDatabase : Database
var members = this.Tables.Create<Member, int>(x => x.Id);
var groups = base.Tables.Create<Group, int>(g => g.Id);
RelationOptions options = new RelationOptions(
var peopleGroupIdIndex = members.CreateIndex(
new RedBlackTreeIndexFactory(),
this.Tables.CreateRelation(
public ITable<Member> Members { get; private set; }
public ITable<Group> Groups { get; private set; }
public int Id { get; set; }
public string Name { get; set; }
public int? GroupId { get; set; }
public int Id { get; set; }
public string Name { get; set; }