Software can always be made faster, but rarely can it be made more correct.
Project:M36 implements a relational algebra engine as inspired by the writings of Chris Date.
Unlike most database management systems (DBMS), Project:M36 is opinionated software which adheres strictly to the mathematics of the relational algebra. The purpose of this adherence is to prove that software which implements mathematically-sound design principles reaps benefits in the form of code clarity, consistency, performance, and future-proofing.
Project:M36 can be used as an in-process or remote DBMS.
Project:M36 is written entirely in the Haskell programming language.
Project:M36 supports multiple frontends which target different audiences.
- learn about the relational algebra via TutorialD
- store and manipulate databases
- use Project:M36 as a native Haskell database backend
- Installation and Introduction to Project:M36
- Introduction to the Relational Algebra
- TutorialD Tutorial
- 15 Minute Tutorial
- Developer's Change Log
- Transaction Graph Operators
- Persistent Library Driver
- ProjectM36.Client Library
- Adding New Data Types
- Serving Remote ProjectM36 Databases
- Using Notifications
- Merge Transactions
- WebSocket Server
- Atom (Value) Functions
- Trans-Graph Relational Expressions
- Isomorphic Schemas
Project:M36 is developed in Haskell and compiled with GHC 7.8 or later.
- The Third Manifesto: the philosophical basis for relational algebra engines
- Rel: a TutorialD implementation against a BerkeleyDB backend
- Andl: a new database language with SQLite and PostgreSQL backends
- Coddie: a python-based relational algebra interpreter
- Out of the Tarpit: a proposed software architecture which minimizes state and complexity. Project:M36 implements the requirements of this paper.
- Database Design & Relational Theory: Normal Forms and All That Jazz: mathematical foundations for the principles of the relational algebra
- Database Explorations: Essays on the Third Manifesto and Related Topics: additional essays and debates on practical approaches to relational algebra engine design