Download Chapter 1: Introduction

Survey
yes no Was this document useful for you?
   Thank you for your participation!

* Your assessment is very important for improving the workof artificial intelligence, which forms the content of this project

Document related concepts

DBase wikipedia , lookup

Microsoft Access wikipedia , lookup

SQL wikipedia , lookup

Microsoft SQL Server wikipedia , lookup

Serializability wikipedia , lookup

Entity–attribute–value model wikipedia , lookup

PL/SQL wikipedia , lookup

Oracle Database wikipedia , lookup

IMDb wikipedia , lookup

Ingres (database) wikipedia , lookup

Extensible Storage Engine wikipedia , lookup

Open Database Connectivity wikipedia , lookup

Microsoft Jet Database Engine wikipedia , lookup

Concurrency control wikipedia , lookup

Database wikipedia , lookup

Relational model wikipedia , lookup

Clusterpoint wikipedia , lookup

ContactPoint wikipedia , lookup

Database model wikipedia , lookup

Transcript
Chapter 1: Introduction
 Why Database Systems?
 Data Models
 Data Definition Language
 Data Manipulation Language
 Transaction Management
 Storage Management
Database System Concepts
1.1
©Silberschatz, Korth and Sudarshan
Database Management System (DBMS)
 Collection of interrelated Information
 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 and data is kept safely
 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
 Information management is the focus of all applications
Database System Concepts
1.2
©Silberschatz, Korth and Sudarshan
Information vs Computation
 Computational focus: Algorithms, Procedural Languages, Data
Structures
 Informational focus: Data Models, Data Definition Languages,
Declarative Query Languages
 Advanced computational technology to support these inside the
Database Management System is largely hidden from users
 Databases produced this paradigm shift in the `70s with the
relational model.
 An incredible commercial success
 The internet has reinforced the shift from a computational
to an informational focus
 Boundaries between web and DBs are getting blurred. Eg.
XML schema and Xquery are the data-definition and query
languages for the web.
Database System Concepts
1.3
©Silberschatz, Korth and Sudarshan
Conceptual: Data Model
The entity-relationship data model (E-R: model)
A nice conceptual schemas for software specification:
generalized in UML (Universal Modeling Language)
But we want to see the data too …
Database System Concepts
1.4
©Silberschatz, Korth and Sudarshan
Relational Model
Attributes
 Relational schema and data in the same table
Customerid
customername
192-83-7465
Johnson
019-28-3746
Smith
192-83-7465
Johnson
321-12-3123
Jones
019-28-3746
Smith
Database System Concepts
customerstreet
customercity
accountnumber
Alma
Palo Alto
A-101
North
Rye
A-215
Alma
Palo Alto
A-201
Main
Harrison
A-217
North
Rye
A-201
1.5
©Silberschatz, Korth and Sudarshan
A Sample Relational Database
Database System Concepts
1.6
©Silberschatz, Korth and Sudarshan
Data Definition Language (DDL)
 Specification notation for defining the database
schema—start with record types.
 E.g.
create table account (
account-number char(10),
balance
integer)
 DDL compiler generates a set of tables
 Data dictionary contains metadata (i.e., schema,
indexes, users, authorization, …, the database of the
DBMS)
Database System Concepts
1.7
©Silberschatz, Korth and Sudarshan
Data Manipulation Language (DML)
 Language for accessing and manipulating the data
organized by the appropriate data model
 DML also known as `Query Language’
 SQL is the standard query language
 Standards are important because it allows different DBs to
cooperate, applications to migrate
 Relational Algebra: an operator-based language.
Equivalent to SQL and closer to implementation.
Database System Concepts
1.8
©Silberschatz, Korth and Sudarshan
SQL
 SQL: widely used non-procedural language
 E.g. find the name of the customer with customer-id 192-83-7465
select customer.customer-name
from customer
where customer.customer-id = ‘192-83-7465’
 E.g. find the balances of all accounts held by the customer with
customer-id 192-83-7465
select account.balance
from depositor, account
where depositor.customer-id = ‘192-83-7465’ and
depositor.account-number = account.account-number
 Application programs generally access databases through one of
 Language extensions to allow embedded SQL
 Application program interface (e.g. ODBC/JDBC) which allow SQL
queries to be sent to a database
Database System Concepts
1.9
©Silberschatz, Korth and Sudarshan
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 – pose queries 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
Database System Concepts
1.10
©Silberschatz, Korth and Sudarshan
Database Management Systems:
Enabling Technology
 The storage manager:
 efficient storing, retrieving and updating of data
 Support for indexes and access methods
 Query Compiler and Optimizer
 Authorization and security
 Integrity constraint enforcement
 Transaction Management and Concurrency
control
 Recovery
Database System Concepts
1.11
©Silberschatz, Korth and Sudarshan
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.
Database System Concepts
1.12
©Silberschatz, Korth and Sudarshan
Overall System Structure
Database System Concepts
1.13
©Silberschatz, Korth and Sudarshan
Database Administrator
 Coordinates all the activities of the database
system; the database administrator has a good
understanding of the enterprise’s information
resources and needs.
 Database administrator 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
Database System Concepts
1.14
©Silberschatz, Korth and Sudarshan
Who needs DBMSs?
 In the early days, database applications were built on top
of file systems
 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
 No Data Integration— 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
Database System Concepts
1.15
©Silberschatz, Korth and Sudarshan
Who need DBMSs? (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
 Also data independence: physical and logical.
Database System Concepts
1.16
©Silberschatz, Korth and Sudarshan