04 Part II Intro to Database Systems Andy Pavlo AP AP - - PowerPoint PPT Presentation

04
SMART_READER_LITE
LIVE PREVIEW

04 Part II Intro to Database Systems Andy Pavlo AP AP - - PowerPoint PPT Presentation

Database Storage 04 Part II Intro to Database Systems Andy Pavlo AP AP 15-445/15-645 Computer Science Fall 2020 Carnegie Mellon University 2 ADM INISTRIVIA Project #1 will be released on September 14 th 15-445/645 (Fall 2020) 3 DISK-


slide-1
SLIDE 1

Intro to Database Systems 15-445/15-645 Fall 2020 Andy Pavlo Computer Science Carnegie Mellon University

AP AP

04

Database Storage Part II

slide-2
SLIDE 2

15-445/645 (Fall 2020)

ADM INISTRIVIA

Project #1 will be released on September 14th

2

slide-3
SLIDE 3

15-445/645 (Fall 2020)

DISK- O RIEN TED ARCHITECTURE

The DBMS assumes that the primary storage location of the database is on non-volatile disk. The DBMS's components manage the movement

  • f data between non-volatile and volatile storage.

3

slide-4
SLIDE 4

15-445/645 (Fall 2020)

SLOTTED PAGES

The most common layout scheme is called slotted pages. The slot array maps "slots" to the tuples' starting position offsets. The header keeps track of:

→ The # of used slots → The offset of the starting location of the last slot used.

4

Header Tuple #4 Tuple #2 Tuple #3 Tuple #1

Fixed/Var-length Tuple Data Slot Array

slide-5
SLIDE 5

15-445/645 (Fall 2020)

SLOTTED PAGES

The most common layout scheme is called slotted pages. The slot array maps "slots" to the tuples' starting position offsets. The header keeps track of:

→ The # of used slots → The offset of the starting location of the last slot used.

4

Header Tuple #4 Tuple #2 Tuple #3 Tuple #1

Fixed/Var-length Tuple Data Slot Array

slide-6
SLIDE 6

15-445/645 (Fall 2020)

LOG- STRUCTURED FILE ORGANIZATIO N

Instead of storing tuples in pages, the DBMS only stores log records. The system appends log records to the file of how the database was modified:

→ Inserts store the entire tuple. → Deletes mark the tuple as deleted. → Updates contain the delta of just the attributes that were modified.

5

slide-7
SLIDE 7

15-445/645 (Fall 2020)

LOG- STRUCTURED FILE ORGANIZATIO N

Instead of storing tuples in pages, the DBMS only stores log records. The system appends log records to the file of how the database was modified:

→ Inserts store the entire tuple. → Deletes mark the tuple as deleted. → Updates contain the delta of just the attributes that were modified.

5

New Entries

INSERT id=1,val=a INSERT id=2,val=b DELETE id=4 UPDATE val=X (id=3) UPDATE val=Y (id=4) INSERT id=3,val=c

Page

slide-8
SLIDE 8

15-445/645 (Fall 2020)

LOG- STRUCTURED FILE ORGANIZATIO N

To read a record, the DBMS scans the log backwards and "recreates" the tuple to find what it needs.

6

INSERT id=1,val=a INSERT id=2,val=b DELETE id=4 UPDATE val=X (id=3) UPDATE val=Y (id=4) INSERT id=3,val=c

Reads Page

slide-9
SLIDE 9

15-445/645 (Fall 2020)

LOG- STRUCTURED FILE ORGANIZATIO N

To read a record, the DBMS scans the log backwards and "recreates" the tuple to find what it needs. Build indexes to allow it to jump to locations in the log.

6

INSERT id=1,val=a INSERT id=2,val=b DELETE id=4 UPDATE val=X (id=3) UPDATE val=Y (id=4) INSERT id=3,val=c

id=1 id=2 id=3 id=4

Page

slide-10
SLIDE 10

15-445/645 (Fall 2020)

LOG- STRUCTURED FILE ORGANIZATIO N

To read a record, the DBMS scans the log backwards and "recreates" the tuple to find what it needs. Build indexes to allow it to jump to locations in the log. Periodically compact the log.

6

id=1,val=a id=2,val=b id=3,val=X id=4,val=Y

Page

slide-11
SLIDE 11

15-445/645 (Fall 2020)

LOG- STRUCTURED FILE ORGANIZATIO N

To read a record, the DBMS scans the log backwards and "recreates" the tuple to find what it needs. Build indexes to allow it to jump to locations in the log. Periodically compact the log.

6

id=1,val=a id=2,val=b id=3,val=X id=4,val=Y

Page

slide-12
SLIDE 12

15-445/645 (Fall 2020)

LOG- STRUCTURED COM PACTIO N

Compaction coalesces larger log files into smaller files by removing unnecessary records.

7 Sorted Log File

Level 0

Compaction

Sorted Log File

Level Compaction

slide-13
SLIDE 13

15-445/645 (Fall 2020)

LOG- STRUCTURED COM PACTIO N

Compaction coalesces larger log files into smaller files by removing unnecessary records.

7 Sorted Log File

Level 0 Level 1

Compaction

Level Compaction

slide-14
SLIDE 14

15-445/645 (Fall 2020)

LOG- STRUCTURED COM PACTIO N

Compaction coalesces larger log files into smaller files by removing unnecessary records.

7 Sorted Log File Sorted Log File Sorted Log File

Level 0 Level 1 Level 2

Compaction

Sorted Log File Sorted Log File

Level Compaction

slide-15
SLIDE 15

15-445/645 (Fall 2020)

LOG- STRUCTURED COM PACTIO N

Compaction coalesces larger log files into smaller files by removing unnecessary records.

7 Sorted Log File Sorted Log File Sorted Log File

Level 0 Level 1 Level 2

Compaction

Sorted Log File Sorted Log File

Level Compaction Universal Compaction

Sorted Log File Sorted Log File Sorted Log File Sorted Log File Sorted Log File Sorted Log File Sorted Log File

slide-16
SLIDE 16

15-445/645 (Fall 2020)

TODAY'S AGENDA

Data Representation System Catalogs Storage Models

8

slide-17
SLIDE 17

15-445/645 (Fall 2020)

TUPLE STORAGE

A tuple is essentially a sequence of bytes. It's the job of the DBMS to interpret those bytes into attribute types and values. The DBMS's catalogs contain the schema information about tables that the system uses to figure out the tuple's layout.

9

slide-18
SLIDE 18

15-445/645 (Fall 2020)

DATA REPRESENTATIO N

INTEGER/BIGINT/SMALLINT/TINYINT

→ C/C++ Representation

FLOAT/REAL vs. NUMERIC/DECIMAL

→ IEEE-754 Standard / Fixed-point Decimals

VARCHAR/VARBINARY/TEXT/BLOB

→ Header with length, followed by data bytes.

TIME/DATE/TIMESTAMP

→ 32/64-bit integer of (micro)seconds since Unix epoch

10

slide-19
SLIDE 19

15-445/645 (Fall 2020)

VARIABLE PRECISIO N NUM BERS

Inexact, variable-precision numeric type that uses the "native" C/C++ types.

→ Examples: FLOAT, REAL/DOUBLE

Store directly as specified by IEEE-754. Typically faster than arbitrary precision numbers but can have rounding errors…

11

slide-20
SLIDE 20

15-445/645 (Fall 2020)

VARIABLE PRECISIO N NUM BERS

12

#include <stdio.h> int main(int argc, char* argv[]) { float x = 0.1; float y = 0.2; printf("x+y = %f\n", x+y); printf("0.3 = %f\n", 0.3); }

Rounding Example

x+y = 0.300000 0.3 = 0.300000

Output

slide-21
SLIDE 21

15-445/645 (Fall 2020)

VARIABLE PRECISIO N NUM BERS

12

#include <stdio.h> int main(int argc, char* argv[]) { float x = 0.1; float y = 0.2; printf("x+y = %f\n", x+y); printf("0.3 = %f\n", 0.3); }

Rounding Example

x+y = 0.300000 0.3 = 0.300000

Output

#include <stdio.h> int main(int argc, char* argv[]) { float x = 0.1; float y = 0.2; printf("x+y = %.20f\n", x+y); printf("0.3 = %.20f\n", 0.3); } x+y = 0.30000001192092895508 0.3 = 0.29999999999999998890

slide-22
SLIDE 22

15-445/645 (Fall 2020)

FIXED PRECISIO N NUM BERS

Numeric data types with (potentially) arbitrary precision and scale. Used when rounding errors are unacceptable.

→ Example: NUMERIC, DECIMAL

Many different implementations.

→ Example: Store in an exact, variable-length binary representation with additional meta-data. → Can be less expensive if you give up arbitrary precision.

Demo: Postgres, MySQL, SQL Server, Oracle

13

slide-23
SLIDE 23

15-445/645 (Fall 2020)

POSTGRES: NUM ERIC

14

typedef unsigned char NumericDigit; typedef struct { int ndigits; int weight; int scale; int sign; NumericDigit *digits; } numeric;

# of Digits Weight of 1st Digit Scale Factor Positive/Negative/NaN Digit Storage

slide-24
SLIDE 24

15-445/645 (Fall 2020)

POSTGRES: NUM ERIC

14

typedef unsigned char NumericDigit; typedef struct { int ndigits; int weight; int scale; int sign; NumericDigit *digits; } numeric;

# of Digits Weight of 1st Digit Scale Factor Positive/Negative/NaN Digit Storage

slide-25
SLIDE 25

15-445/645 (Fall 2020)

MYSQ L: NUM ERIC

15

typedef int32 decimal_digit_t; struct decimal_t { int intg, frac, len; bool sign; decimal_digit_t *buf; };

# of Digits Before Point # of Digits After Point Length (Bytes) Positive/Negative Digit Storage

slide-26
SLIDE 26

15-445/645 (Fall 2020)

MYSQ L: NUM ERIC

15

typedef int32 decimal_digit_t; struct decimal_t { int intg, frac, len; bool sign; decimal_digit_t *buf; };

# of Digits Before Point # of Digits After Point Length (Bytes) Positive/Negative Digit Storage

slide-27
SLIDE 27

15-445/645 (Fall 2020)

LARGE VALUES

Most DBMSs don't allow a tuple to exceed the size of a single page. To store values that are larger than a page, the DBMS uses separate

  • verflow storage pages.

→ Postgres: TOAST (>2KB) → MySQL: Overflow (>½ size of page) → SQL Server: Overflow (>size of page)

16

Overflow Page

VARCHAR DATA

Tuple

Header a b c d e

slide-28
SLIDE 28

15-445/645 (Fall 2020)

EXTERNAL VALUE STORAGE

Some systems allow you to store a really large value in an external file. Treated as a BLOB type.

→ Oracle: BFILE data type → Microsoft: FILESTREAM data type

The DBMS cannot manipulate the contents of an external file.

→ No durability protections. → No transaction protections.

17

Data

Header a b c d e

External File Tuple

slide-29
SLIDE 29

15-445/645 (Fall 2020)

EXTERNAL VALUE STORAGE

Some systems allow you to store a really large value in an external file. Treated as a BLOB type.

→ Oracle: BFILE data type → Microsoft: FILESTREAM data type

The DBMS cannot manipulate the contents of an external file.

→ No durability protections. → No transaction protections.

17

Data

Header a b c d e

External File Tuple

slide-30
SLIDE 30

15-445/645 (Fall 2020)

SYSTEM CATALOGS

A DBMS stores meta-data about databases in its internal catalogs.

→ Tables, columns, indexes, views → Users, permissions → Internal statistics

Almost every DBMS stores databases' catalogs in another database.

→ Wrap object abstraction around tuples. → Specialized code for "bootstrapping" catalog tables.

18

slide-31
SLIDE 31

15-445/645 (Fall 2020)

SYSTEM CATALOGS

You can query the DBMS’s internal INFORMATION_SCHEMA catalog to get info about the database.

→ ANSI standard set of read-only views that provide info about all the tables, views, columns, and procedures in a database

DBMSs also have non-standard shortcuts to retrieve this information.

19

slide-32
SLIDE 32

15-445/645 (Fall 2020)

ACCESSIN G TABLE SCHEM A

List all the tables in the current database:

20

SELECT * FROM INFORMATION_SCHEMA.TABLES WHERE table_catalog = '<db name>';

SQL- 92 92

\d;

Postgres

SHOW TABLES;

MySQL

.tables

SQLite

slide-33
SLIDE 33

15-445/645 (Fall 2020)

ACCESSIN G TABLE SCHEM A

List all the tables in the student table:

21

SELECT * FROM INFORMATION_SCHEMA.TABLES WHERE table_name = 'student'

SQL- 92 92

\d student;

Postgres

DESCRIBE student;

MySQL

.schema student

SQLite

slide-34
SLIDE 34

15-445/645 (Fall 2020)

DATABASE WORKLOADS

On-Line Transaction Processing (OLTP)

→ Fast operations that only read/update a small amount of data each time.

On-Line Analytical Processing (OLAP)

→ Complex queries that read a lot of data to compute aggregates.

Hybrid Transaction + Analytical Processing

→ OLTP + OLAP together on the same database instance

24

slide-35
SLIDE 35

15-445/645 (Fall 2020)

DATABASE WORKLOADS

Writes Reads Simple Complex

Workload Focus Operation Complexity

OLTP OLAP

[SOURCE]

HTAP

slide-36
SLIDE 36

15-445/645 (Fall 2020)

BIFURCATED ENVIRON M EN T

26

Extract Transform Load OLAP Data Warehouse OLTP Data Silos

Analytical Queries Transactions

slide-37
SLIDE 37

15-445/645 (Fall 2020)

BIFURCATED ENVIRON M EN T

26

Extract Transform Load OLAP Data Warehouse

Analytical Queries Transactions

HTAP Database

slide-38
SLIDE 38

15-445/645 (Fall 2020)

OBSERVATION

The relational model does not specify that we must store all of a tuple's attributes together in a single page. This may not actually be the best layout for some workloads…

27

slide-39
SLIDE 39

15-445/645 (Fall 2020)

WIKIPEDIA EXAM PLE

28

CREATE TABLE revisions ( revID INT PRIMARY KEY, userID INT REFERENCES useracct (userID), pageID INT REFERENCES pages (pageID), content TEXT, updated DATETIME ); CREATE TABLE pages ( pageID INT PRIMARY KEY, title VARCHAR UNIQUE, latest INT ⮱REFERENCES revisions (revID), ); CREATE TABLE useracct ( userID INT PRIMARY KEY, userName VARCHAR UNIQUE, ⋮ );

slide-40
SLIDE 40

15-445/645 (Fall 2020)

OLTP

On-line Transaction Processing:

→ Simple queries that read/update a small amount of data that is related to a single entity in the database.

This is usually the kind of application that people build first.

29

UPDATE useracct SET lastLogin = NOW(), hostname = ? WHERE userID = ? INSERT INTO revisions VALUES (?,?…,?) SELECT P.*, R.* FROM pages AS P INNER JOIN revisions AS R ON P.latest = R.revID WHERE P.pageID = ?

slide-41
SLIDE 41

15-445/645 (Fall 2020)

OLAP

On-line Analytical Processing:

→ Complex queries that read large portions

  • f the database spanning multiple entities.

You execute these workloads on the data you have collected from your OLTP application(s).

30

SELECT COUNT(U.lastLogin), EXTRACT(month FROM U.lastLogin) AS month FROM useracct AS U WHERE U.hostname LIKE '%.gov' GROUP BY EXTRACT(month FROM U.lastLogin)

slide-42
SLIDE 42

15-445/645 (Fall 2020)

DATA STORAGE M ODELS

The DBMS can store tuples in different ways that are better for either OLTP or OLAP workloads. We have been assuming the n-ary storage model (aka "row storage") so far this semester.

31

slide-43
SLIDE 43

15-445/645 (Fall 2020)

N- ARY STORAGE M ODEL (NSM )

The DBMS stores all attributes for a single tuple contiguously in a page. Ideal for OLTP workloads where queries tend to

  • perate only on an individual entity and insert-

heavy workloads.

32

slide-44
SLIDE 44

15-445/645 (Fall 2020)

N- ARY STORAGE M ODEL (NSM )

The DBMS stores all attributes for a single tuple contiguously in a page.

33

←Tuple # 1

userID userName userPass lastLogin hostname userID userName userPass lastLogin hostname userID userName userPass lastLogin hostname

  • Header

Header Header Header

slide-45
SLIDE 45

15-445/645 (Fall 2020)

N- ARY STORAGE M ODEL (NSM )

The DBMS stores all attributes for a single tuple contiguously in a page.

33

←Tuple # 1 ←Tuple # 2 ←Tuple # 3 ←Tuple # 4

userID userName userPass lastLogin hostname userID userName userPass lastLogin hostname userID userName userPass lastLogin hostname

  • Header

Header Header Header

slide-46
SLIDE 46

15-445/645 (Fall 2020)

N- ARY STORAGE M ODEL (NSM )

The DBMS stores all attributes for a single tuple contiguously in a page.

33

NSM Disk Page

userID userName userPass lastLogin hostname userID userName userPass lastLogin hostname userID userName userPass lastLogin hostname

  • Header

Header Header Header

slide-47
SLIDE 47

15-445/645 (Fall 2020)

N- ARY STORAGE M ODEL (NSM )

34

SELECT * FROM useracct WHERE userName = ? AND userPass = ?

Index

Lecture 7

slide-48
SLIDE 48

15-445/645 (Fall 2020)

N- ARY STORAGE M ODEL (NSM )

34

SELECT * FROM useracct WHERE userName = ? AND userPass = ?

Index

Lecture 7

slide-49
SLIDE 49

15-445/645 (Fall 2020)

N- ARY STORAGE M ODEL (NSM )

34

SELECT * FROM useracct WHERE userName = ? AND userPass = ?

Index

NSM Disk Page

userID userName userPass lastLogin hostname userID userName userPass lastLogin hostname userID userName userPass lastLogin hostname

  • Header

Header Header Header

Lecture 7

slide-50
SLIDE 50

15-445/645 (Fall 2020)

N- ARY STORAGE M ODEL (NSM )

34

SELECT * FROM useracct WHERE userName = ? AND userPass = ?

Index

INSERT INTO useracct VALUES (?,?,…?)

NSM Disk Page

userID userName userPass lastLogin hostname userID userName userPass lastLogin hostname userID userName userPass lastLogin hostname

  • Header

Header Header Header

Lecture 7

slide-51
SLIDE 51

15-445/645 (Fall 2020)

N- ARY STORAGE M ODEL (NSM )

34

SELECT * FROM useracct WHERE userName = ? AND userPass = ?

Index

INSERT INTO useracct VALUES (?,?,…?)

NSM Disk Page

userID userName userPass lastLogin hostname userID userName userPass lastLogin hostname userID userName userPass lastLogin hostname

  • Header

Header Header Header

userID userName userPass lastLogin hostname

Header

Lecture 7

slide-52
SLIDE 52

15-445/645 (Fall 2020)

N- ARY STORAGE M ODEL (NSM )

35

SELECT COUNT(U.lastLogin), EXTRACT(month FROM U.lastLogin) AS month FROM useracct AS U WHERE U.hostname LIKE '%.gov' GROUP BY EXTRACT(month FROM U.lastLogin)

slide-53
SLIDE 53

15-445/645 (Fall 2020)

N- ARY STORAGE M ODEL (NSM )

35

NSM Disk Page

userID userName userPass lastLogin hostname userID userName userPass lastLogin hostname userID userName userPass lastLogin hostname userID userName userPass lastLogin hostname

Header Header Header Header

SELECT COUNT(U.lastLogin), EXTRACT(month FROM U.lastLogin) AS month FROM useracct AS U WHERE U.hostname LIKE '%.gov' GROUP BY EXTRACT(month FROM U.lastLogin)

slide-54
SLIDE 54

15-445/645 (Fall 2020)

N- ARY STORAGE M ODEL (NSM )

35

NSM Disk Page

userID userName userPass lastLogin hostname userID userName userPass lastLogin hostname userID userName userPass lastLogin hostname userID userName userPass lastLogin hostname

Header Header Header Header

SELECT COUNT(U.lastLogin), EXTRACT(month FROM U.lastLogin) AS month FROM useracct AS U WHERE U.hostname LIKE '%.gov' GROUP BY EXTRACT(month FROM U.lastLogin)

slide-55
SLIDE 55

15-445/645 (Fall 2020)

N- ARY STORAGE M ODEL (NSM )

35

NSM Disk Page

userID userName userPass lastLogin hostname userID userName userPass lastLogin hostname userID userName userPass lastLogin hostname userID userName userPass lastLogin hostname

Header Header Header Header

SELECT COUNT(U.lastLogin), EXTRACT(month FROM U.lastLogin) AS month FROM useracct AS U WHERE U.hostname LIKE '%.gov' GROUP BY EXTRACT(month FROM U.lastLogin)

slide-56
SLIDE 56

15-445/645 (Fall 2020)

N- ARY STORAGE M ODEL (NSM )

35

NSM Disk Page

userID userName userPass lastLogin hostname userID userName userPass lastLogin hostname userID userName userPass lastLogin hostname userID userName userPass lastLogin hostname

Header Header Header Header

Useless Data

SELECT COUNT(U.lastLogin), EXTRACT(month FROM U.lastLogin) AS month FROM useracct AS U WHERE U.hostname LIKE '%.gov' GROUP BY EXTRACT(month FROM U.lastLogin)

slide-57
SLIDE 57

15-445/645 (Fall 2020)

N- ARY STORAGE M ODEL

Advantages

→ Fast inserts, updates, and deletes. → Good for queries that need the entire tuple.

Disadvantages

→ Not good for scanning large portions of the table and/or a subset of the attributes.

36

slide-58
SLIDE 58

15-445/645 (Fall 2020)

DECOM POSITIO N STORAGE M ODEL (DSM )

The DBMS stores the values of a single attribute for all tuples contiguously in a page.

→ Also known as a "column store".

Ideal for OLAP workloads where read-only queries perform large scans over a subset of the table’s attributes.

37

slide-59
SLIDE 59

15-445/645 (Fall 2020)

DECOM POSITIO N STORAGE M ODEL (DSM )

The DBMS stores the values of a single attribute for all tuples contiguously in a page.

→ Also known as a "column store".

38

userID userName userPass lastLogin hostname userID userName userPass lastLogin hostname userID userName userPass lastLogin hostname userID userName userPass lastLogin hostname

Header Header Header Header

slide-60
SLIDE 60

15-445/645 (Fall 2020)

DECOM POSITIO N STORAGE M ODEL (DSM )

The DBMS stores the values of a single attribute for all tuples contiguously in a page.

→ Also known as a "column store".

38

userID userName userPass lastLogin hostname userID userName userPass lastLogin hostname userID userName userPass lastLogin hostname userID userName userPass lastLogin hostname

Header Header Header Header

slide-61
SLIDE 61

15-445/645 (Fall 2020)

DECOM POSITIO N STORAGE M ODEL (DSM )

The DBMS stores the values of a single attribute for all tuples contiguously in a page.

→ Also known as a "column store".

38

userID userName userPass

DSM Disk Page

hostname hostname hostname hostname hostname hostname hostname hostname hostname hostname hostname hostname hostname hostname hostname hostname hostname hostname hostname hostname hostname hostname hostname hostname

lastLogin

slide-62
SLIDE 62

15-445/645 (Fall 2020)

DECOM POSITIO N STORAGE M ODEL (DSM )

39

SELECT COUNT(U.lastLogin), EXTRACT(month FROM U.lastLogin) AS month FROM useracct AS U WHERE U.hostname LIKE '%.gov' GROUP BY EXTRACT(month FROM U.lastLogin)

slide-63
SLIDE 63

15-445/645 (Fall 2020)

DSM Disk Page

hostname hostname hostname hostname hostname hostname hostname hostname hostname hostname hostname hostname hostname hostname hostname hostname hostname hostname hostname hostname hostname hostname hostname hostname

DECOM POSITIO N STORAGE M ODEL (DSM )

39

SELECT COUNT(U.lastLogin), EXTRACT(month FROM U.lastLogin) AS month FROM useracct AS U WHERE U.hostname LIKE '%.gov' GROUP BY EXTRACT(month FROM U.lastLogin)

slide-64
SLIDE 64

15-445/645 (Fall 2020)

TUPLE IDENTIFICATIO N

Choice #1: Fixed-length Offsets

→ Each value is the same length for an attribute.

Choice #2: Embedded Tuple Ids

→ Each value is stored with its tuple id in a column.

40

Offsets

1 2 3

A B C D

Embedded Ids

A

1 2 3

B

1 2 3

C

1 2 3

D

1 2 3

slide-65
SLIDE 65

15-445/645 (Fall 2020)

DECOM POSITIO N STORAGE M ODEL (DSM )

Advantages

→ Reduces the amount wasted I/O because the DBMS only reads the data that it needs. → Better query processing and data compression (more on this later).

Disadvantages

→ Slow for point queries, inserts, updates, and deletes because of tuple splitting/stitching.

41

slide-66
SLIDE 66

15-445/645 (Fall 2020)

DSM SYSTEM HISTORY

1970s: Cantor DBMS 1980s: DSM Proposal 1990s: SybaseIQ (in-memory only) 2000s: Vertica, VectorWise, MonetDB 2010s: Everyone

42

slide-67
SLIDE 67

15-445/645 (Fall 2020)

CONCLUSIO N

The storage manager is not entirely independent from the rest of the DBMS. It is important to choose the right storage model for the target workload:

→ OLTP = Row Store → OLAP = Column Store

43

slide-68
SLIDE 68

15-445/645 (Fall 2020)

DATABASE STORAGE

Problem #1: How the DBMS represents the database in files on disk. Problem #2: How the DBMS manages its memory and move data back-and-forth from disk.

44

← Next