Skip to content

Latest commit

 

History

History
64 lines (51 loc) · 2.08 KB

README.md

File metadata and controls

64 lines (51 loc) · 2.08 KB

Database Architecture Course

This is a course for Enterprise/Web Software Developers. It goes into details of Relational Databases (RDBMS):

  • What they are good for
  • How to design DB schemas
  • How to properly access DB from our application code

Programme

Types of databases

  • Log-structured Merge Trees (LSM)
  • Heap-organized tables
  • Index-organized tables (tables with Clustered Indices)
  • Document-oriented
  • Relational
  • Graph-oriented
  • OLTP vs OLAP
  • Replication

Database Index

  • B+ Tree, Hash Tables, Bitmaps
  • Primary & Secondary index
  • Composite Index
  • Performance of Index vs Sequential Table Scan
  • Analyzing Query Plan
  • Foreign Keys, Unique Constraints
  • Clustered Index, Covering Index

Joins

  • Nested Loops
  • Merge Join
  • Hash Join
  • Analyzing Query Plan

Concurrency and Transactions

  • Concurrency intro: MVCC vs Locking
  • Postgres MVCC, isolation: Read Committed, Snapshot, Snapshot Serializable (SSI)
  • Mysql vs Postgres MVCC
  • Pessimistic Locking
  • skip locked and background jobs
  • Optimistic Locking
  • Materializing locks
  • Advisory locks
  • Durability & Write-ahead logging
  • Data Anomalies: Dirty Write, Dirty Read, Non-repeatable Read, Phantoms, Lost Update, Write Skew
  • Concurrency with locking. Locking, 2 Phase Locking (2PL); isolation: Read Committed, Repeatable Read, Serializable
  • Hot backups
  • Redo and Undo logs
  • Dead Locks
  • Index, MVCC, Visibility Maps
  • Index vs Isolation vs Unique Constraints

Application code