Relational - (PostgreSQL, MySQL, SQL Server, Oracle)
- Tabular - (like an Excel spreadsheet)
- Structured - (rows and columns)
- Consistency - (datatypes & constraints. Limit allowed input to improve quality)
Best when
- Clearly defined data structures & relationships. Can be easily Normalised
- Data quality matters or needs constraining
Non-Relational - (MongoDB, Cassandra, Redis, Couchbase, DynamoDB)
- Less structured - (flexibility for inconsistent keys or arrays)
- Data largely unrelated - (no schemas, tables cannot be reliably joined)
Best when
- The data structure cannot be clearly defined
- If data inputs are variant and flexibility matters
Graph Database - (AWS Neptune, Neo4J, HyperGraphDB, ArangoDB)
- Nodes & Edges - (every node is related to other nodes via edges)
- No structure - (relationships at record level)
Best when
- Everything is related to everything else
- Deep-dive network analysis is required (e.g. fraud detection)
data:image/s3,"s3://crabby-images/4f81a/4f81ade6aec3c7c6d50c3f95199fa28559f01de5" alt=""
data:image/s3,"s3://crabby-images/83e67/83e67378799b709361def8029d6c8aa6aa72315c" alt=""
data:image/s3,"s3://crabby-images/c32cb/c32cb39ae4d188b752f7e2393073224d51715ad4" alt=""