Top Banner
DBMS and Applications 1 Foundations of Database Systems Introduction to DBMS Instructor: Zhijun Wang
43
Welcome message from author
This document is posted to help you gain knowledge. Please leave a comment to let me know what you think about it! Share it to your friends and learn new things together.
Transcript
Page 1: Lesson_1

DBMS and Applications 1

Foundations of Database Systems

Introduction to DBMS

Instructor: Zhijun Wang

Page 2: Lesson_1

DBMS and Applications 2

Storing Data Using files Drawbacks of using file systems to store data:

Data redundancy and inconsistency Multiple file formats, duplication of information in different

files Difficulty in accessing data

Need to write a new program to carry out each new task Data isolation — multiple files and formats Integrity problems

Integrity constraints (e.g. account balance > 0) become part of program code

Hard to add new constraints or change existing ones

Page 3: Lesson_1

DBMS and Applications 3

Drawbacks of File Systems - cont

Atomicity of updates Failures may leave database in an inconsistent state with partial

updates carried out E.g. transfer of funds from one account to another should either

complete or not happen at all Concurrent access by multiple users

Concurrent accessed needed for performance Uncontrolled concurrent accesses can lead to inconsistencies

E.g. two people reading a balance and updating it at the same time

Security problems Database systems offer solutions to all the above

problems

Page 4: Lesson_1

DBMS and Applications 4

Database Management System

Collection of interrelated data Set of programs to access the data DBMS contains information about a

particular enterprise DBMS provides an environment that is both

convenient and efficient to use.

Page 5: Lesson_1

DBMS and Applications 5

The Hierarchy of Data

File-Processing

DBMS

Page 6: Lesson_1

DBMS and Applications 6

Database Management System

Database Applications: Banking: all transactions Airlines: reservations, schedules Universities: registration, grades Sales: customers, products, purchases Manufacturing: production, inventory, orders, supply

chain Human resources: employee records, salaries, tax

deductions Databases touch all aspects of our lives

Page 7: Lesson_1

DBMS and Applications 7

Art or Engineering

Database design and development involves both art and engineering Gathering and organizing user requirements is

an art Transforming the resulting designs into

physical applications involves engineering

Page 8: Lesson_1

DBMS and Applications 8

Database Example 1

Mary Richards Housepainting Self Employed Entrepreneur Single User Database 3 Tables (Customers, Jobs, Source) Data Needs:

Track how customers, jobs, and referrals relate Record bid estimates Track referral sources Produce mailing labels

Page 9: Lesson_1

DBMS and Applications 9

Mary Richards’ Tables

SOURCE

CUSTOMER

JOB

Page 10: Lesson_1

DBMS and Applications 10

Database Example 2

Treble Clef Music Multi-User database on LAN 3 Tables (Customers, Instruments, Rentals) Data Needs:

Track instrument rentals Handle multi-user issues

Page 11: Lesson_1

DBMS and Applications 11

Treble Clef Form 1

Page 12: Lesson_1

DBMS and Applications 12

Treble Clef Form 2

Page 13: Lesson_1

DBMS and Applications 13

Treble Clef Form 3

Page 14: Lesson_1

DBMS and Applications 14

Database Example 3

State Licensing & Vehicle Registration Bureau 52 Centers, 37 Offices, Hundreds of Users 40 Tables Data Needs:

Track drivers licensing issues traffic violations, accidents, arrests, limitations

Track auto registration issues revenue, law enforcement

Integrate the needs of many departments

Page 15: Lesson_1

DBMS and Applications 15

Database Example 4

Calvert Island Reservations Centre Chamber of Commerce Promotional database provides access to data Customer and reservation database processes Data Needs:

Store multimedia data (photos, video clips, sound clips) Must be Web / browser accessible Uses Web technologies including HTTP, DHTML, and XML

Page 16: Lesson_1

DBMS and Applications 16

Comparison Among Examples

Page 17: Lesson_1

DBMS and Applications 17

Data Models A collection of tools for describing

data data relationships data semantics data constraints

Entity-Relationship model Relational model Other models:

object-oriented model semi-structured data models Older models: network model and hierarchical

model

Page 18: Lesson_1

DBMS and Applications 18

Entity-Relationship Model

Example of schema in the entity-relationship

model

Page 19: Lesson_1

DBMS and Applications 19

Entity Relationship Model

E-R model of real world Entities (objects)

E.g. customers, accounts, bank branch Relationships between entities

E.g. Account A-101 is held by customer Johnson Relationship set depositor associates customers with accounts

Widely used for database design Database design in E-R model usually converted to

design in the relational model (coming up next) which is used for storage and processing

Page 20: Lesson_1

DBMS and Applications 20

Defining Tables using Microsoft Access

Page 21: Lesson_1

DBMS and Applications 21

Defining Relationships Among the Tables using Microsoft Access

Page 22: Lesson_1

DBMS and Applications 22

Instances and Schemas Schema – the logical structure of the database

e.g., the database consists of information about a set of customers and accounts and the relationship between them

Analogous to type information of a variable in a program Physical schema: database design at the physical level Logical schema: database design at the logical level

Instance – the actual content of the database at a particular point in time Analogous to the value of a variable

Page 23: Lesson_1

DBMS and Applications 23

Levels of Abstraction Many views and External

Schemas, single conceptual (logical) schema and physical schema.

Views describe how users see the data.

An External Schema is made up of a number of views

Conceptual schema defines logical structure

Physical schema describes the files and indexes used.

Schemas are defined using DDL; data is modified/queried using DML.

Physical Schema

Conceptual Schema

View 1 View 2 View 3

Page 24: Lesson_1

DBMS and Applications 24

Conceptual level: Students (sid: string, name: string, login: string,

age: integer, gpa: real) Course (cid: string, cname: string, credits: integer) Enrolled (sid: string, cid: string, grade: string)

Physical level: Relations stored as unordered files. Index on first column of Students.

External level (View): Course_info (cid: string, enrollment: integer)

Example: University Database

Page 25: Lesson_1

DBMS and Applications 25

Levels of Abstraction Physical level describes how a record (e.g.,

customer) is stored. Logical level: describes data stored in database,

and the relationships among the data.type customer = record

name : string;street : string;city : integer;

end;

View level: application programs hide details of data types. Views can also hide information (e.g., salary) for security purposes.

Page 26: Lesson_1

DBMS and Applications 26

Applications insulated from how data is structured and stored. Logical data independence: Protection from changes in

logical structure of data. conceptual schema changes, the view does not

Physical data independence: Protection from changes in physical structure of data. File structure/indexes change, conceptual schema does not

One of the most important benefits of using a DBMS!

Data Independence

Page 27: Lesson_1

DBMS and Applications 27

Data Definition Language (DDL)

Specification notation for defining the database schema E.g. create table account (

account-number char(10), balance integer)

DDL compiler generates a set of tables stored in a data dictionary

Page 28: Lesson_1

DBMS and Applications 28

Data Definition Language (DDL)

Data dictionary contains metadata (i.e., data about data) database schema Data storage and definition language

language in which the storage structure and access methods used by the database system are specified

Usually an extension of the data definition language

Page 29: Lesson_1

DBMS and Applications 29

Data Manipulation Language DML Language for accessing and manipulating the data

organized by the appropriate data model DML also known as query language

Two classes of languages Procedural – user specifies what data is required and

how to get those data Nonprocedural – user specifies what data is required

without specifying how to get those data SQL is the most widely used non-procedural

query language

Page 30: Lesson_1

DBMS and Applications 30

Database System Components

Page 31: Lesson_1

DBMS and Applications 31

Database Contents

User Data Metadata Indexes Application Metadata

Page 32: Lesson_1

DBMS and Applications 32

User Data

A table of data is called a relation Columns are fields or attributes Rows are entities Relations must be structured

properly

Page 33: Lesson_1

DBMS and Applications 33

Metadata

Metadata describes the structure and format of the data and the overall database

System tables store metadata number of tables and table names number of fields and field names primary key fields field names, data types, and length

Page 34: Lesson_1

DBMS and Applications 34

Indexes

Improve performance Improve accessibility (Overhead data)

Page 35: Lesson_1

DBMS and Applications 35

Application Metadata

Stores the structure and format of forms reports queries other application components

Page 36: Lesson_1

DBMS and Applications 36

The DBMS Engine

Design Tools Subsystem Run-Time Subsystem DBMS Engine

Page 37: Lesson_1

DBMS and Applications 37

Design Tools Subsystem

Tools to design and develop tables forms queries reports

Programming Languages macros languages

Page 38: Lesson_1

DBMS and Applications 38

A Report in Microsoft Access

Page 39: Lesson_1

DBMS and Applications 39

Database Users

Users are differentiated by the way they expect to interact with the system

Application programmers – interact with system through DML calls

Sophisticated users – form requests in a database query language

Specialized users – write specialized database applications that do not fit into the traditional data processing framework

Naïve users – invoke one of the permanent application programs that have been written previously E.g. people accessing database over the web, bank tellers,

clerical staff

Page 40: Lesson_1

DBMS and Applications 40

Transaction Management

A transaction is a collection of operations that performs a single logical function in a database application

Transaction-management component ensures that the database remains in a consistent (correct) state despite system failures (e.g., power failures and operating system crashes) and transaction failures.

Concurrency-control manager controls the interaction among the concurrent transactions, to ensure the consistency of the database.

Page 41: Lesson_1

DBMS and Applications 41

Storage Management

Storage manager is a program module that provides the interface between the low-level data stored in the database and the application programs and queries submitted to the system.

The storage manager is responsible to the following tasks: interaction with the file manager efficient storing, retrieving and updating of data

Page 42: Lesson_1

DBMS and Applications 42

Database Administrator

Database administrator's duties include: Schema definition Storage structure and access method definition Schema and physical organization modification Granting user authority to access the database Specifying integrity constraints Acting as liaison with users Monitoring performance and responding to changes

in requirements

Page 43: Lesson_1

DBMS and Applications 43

Summary DBMS used to maintain, query large data sets. Benefits include recovery from system crashes,

concurrent access, quick application development, data integrity and security.

Levels of abstraction give data independence. A DBMS typically has a layered architecture. DBAs hold responsible jobs and are well-paid! DBMS R&D is one of the broadest, most exciting

areas in CS.