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"});
myDatabase.Members.Insert(new Member() { Id = 1, GroupId = 1, Name = "It's Member_1" });
myDatabase.Members.Insert(new Member() { Id = 2, Name = "It's Member_2" });
from p in myDatabase.Members
join g in myDatabase.Groups on p.GroupId equals g.Id
select new { Name = p.Name, Group = g.Name };
FiddleHelper.WriteTable("Members With Groups",query.ToList());
var groups = myDatabase.Groups.ToList();
var members = myDatabase.Members.ToList();
FiddleHelper.WriteTable("All Groups",groups);
FiddleHelper.WriteTable("All Members",members);
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; }