KEMBAR78
Database management systems Lecture Notes | PDF
DATABASE MANAGEMENT
SYSTEMS
Dr. C. Sreedhar
Professor, CSE Dept.,
G. Pulla Reddy Engineering College, Kurnool
*Some of the images and contents are copied from Internet sources
2
Unit I
• Introduction: Database system, Characteristics (Database
Vs File System), Database Users, Advantages of Database
systems, Database applications.
• Brief introduction of different Data Models; Database
system structure, environment.
• Entity Relationship Model: Introduction, Representation
of entities, attributes, entity set, relationship,
relationship set, constraints, specialization, generalization
using ER Diagrams.
3
Unit II
• Relational Model: Introduction to relational model,
concepts of domain, attribute, tuple, relation,
importance of null values, constraints (Domain, Key
constraints, integrity constraints) and their importance.
• BASIC SQL: Simple Database schema, data types, table
definitions (create, alter),
• DML operations (insert, delete, update).
4
DBMS: Introduction
1. Data
2. Information
3. Database
4. DBMS
5. Database System
1. Raw facts
2. Processed data
3. Collection of related data.
4. Software that manages and
controls access to the database
5. Collection of application
programs that interact with the
database along with the DBMS
and the database itself.
5
Database vs. File System
• The database and the file system are two distinct methods of
storing and managing data.
• While they both handle the storage of information, they differ in
their architecture, functionality, and the types of tasks they are
optimized for.
• File System
File-based systems were an early attempt to computerize the
manual filing system.
• Examples of File system (Decades ago): Banking, Schools, Hospitals
6
Database Vs. File System
Definition
structured system for
storing, managing, and
retrieving data using
specialized software.
Used by operating systems to
store, organize, and manage
files on a storage device.
Structure
Data is stored in tables,
records, and fields, with
relationships between
different tables.
Data is stored as individual
files in a directory
hierarchy. Each file is
independent.
Data
Integrity
A database enforces
integrity constraints to
ensure data consistency
and accuracy.
File systems do not inherently
provide mechanisms for enforcing
data integrity. Data consistency
is left to the application level.
7
Database vs. File System
Data
Retrieval
Uses SQL to retrieve and
manipulate data and supports
complex queries with
filtering, sorting, and
joining data.
Data retrieval is typically
done by opening file and
reading its contents. Complex
queries and relationships
between data are not inherently
supported.
Scalability
Databases are designed to
scale efficiently with large
amounts of data queries.
File systems can manage large
files but do not efficiently
handle large-scale databases
with relational or complex
data models.
Data
Redundancy
Databases are optimized to
minimize redundancy through
normalization (breaking data
into smaller related
tables).
In file systems, data
redundancy can occur as files
are copied, and relationships
between different files are not
managed.
8
Database vs. File system: Use Cases
• Database:
 Managing customer orders and inventory in an e-commerce
application.
 Storing employee information, such as payroll, roles, and attendance
in an HR system.
 Banking transactions in a financial system where data integrity,
relationships, and querying are crucial.
• File System:
 Storing documents, media files, and logs.
 Managing configuration files or text files used by an application.
 Storing backup copies of data or files for long-term archiving.
9
Database vs. File System
• A Database is a highly structured system designed for storing,
managing, and querying large amounts of related data, while a File
System is a basic method of storing and accessing unstructured
data files.
• Databases offer advanced features such as data integrity,
concurrency control, and complex querying, making them ideal for
managing large, structured datasets.
• File Systems are simpler and more suited for managing documents,
images, or other types of unstructured data where relationships
and advanced querying are not required.
10
Limitations of File-Based Approach
• Data Redundancy and Inconsistency
• Difficulty in Data Retrieval
• Separation and isolation of data
• Duplication of data
• Data Integrity Issues
• Concurrency Issues
• Scalability Problems
• Incompatible file formats
11
Database Management System (DBMS)
• DBMS contains information about particular enterprise
 Collection of interrelated data
 Set of programs to access the data
 Environment that is both convenient and efficient to use
• Database Applications:
 Banking: transactions
 Airlines: reservations, schedules
 Universities: registration, grades
 Sales: customers, products, purchases
 Online retailers: order tracking, customized
recommendations
 Manufacturing: production, inventory,orders,supply chain
 Human resources: employee records, salaries, tax
deductions
12
Drawbacks of using file systems
• Data redundancy and inconsistency
 Multiple file formats, duplication in different files
• Difficulty in accessing data
 Need to write new program to carry out each new task
• Data isolation
 Multiple files and formats
• Integrity problems
 Integrity constraints (e.g., account balance > 0)
 Hard to add new constraints or change existing
ones
13
Drawbacks of using file systems contd..
• Atomicity of updates
 Failures may leave database in an inconsistent state with
partial updates carried out
 Example: Transfer of funds from one account to another should
either complete or not happen at all
• Concurrent access by multiple users
 Concurrent access needed for performance
 Uncontrolled concurrent accesses can lead to inconsistencies
• Example: Two people reading a balance (say 100) and updating it by
withdrawing money (say 50 each) at the same time
• Security problems
 Hard to provide user access to some, but not all, data
Database systems offer solutions to all the above problems
14
14
Database Management System
DBMS manages data
resources like an operating
system manages hardware
resources
DBMS Database
containing
centralized
shared data
Application
#1
Application
#2
Application
#3
15
Database Users
Database
16
Database Users
• Database Users: Individuals or applications that interact with the
database to perform operations like querying, updating, and
managing the data.
• Data Administrator
• Database Administrator
• Database Designers
17
Data Administrator
• Data Administrator (DA) is responsible for the management of the
data resource, including database planning; development and
maintenance of standards, policies and procedures; and
conceptual/logical database design.
• The DA consults with and advises senior managers, ensuring that
the direction of database development will ultimately support
corporate objectives
18
Database Administrator
• The Database Administrator (DBA) is responsible for the overall management and
maintenance of the database system.
Responsibilities:
• Database design: Designing database schema, including tables, relationships, constraints.
• Database creation and configuration: Installing, configuring, and maintaining the DBMS.
• Security Mgmt.: Managing user access, privileges, roles, and ensuring data security.
• Backup and recovery: Ensuring that data is regularly backed up & recovered upon failure.
• Performance tuning: Monitoring database performance and optimizing queries, indexing,
and storage.
• Data migration: Migrating data from one system to another or upgrading DBMS versions.
• Ensuring data integrity and consistency: Enforcing data constraints (e.g., primary keys,
foreign keys, etc.) and ensuring the consistency of data.
• Tools: SQL Server Management Studio, Oracle Enterprise Manager, MySQL Workbench.
19
Application Developers
• Application Developers design and develop software applications that interact with the
database. These applications can be for business operations, analytics, or other purposes.
Responsibilities:
• Database design: Application developers work with the DBA to ensure the application’s
database design meets the application's needs.
• Database integration: Writing code that allows application to interact with the database
using SQL queries and other database access methods.
• Data Manipulation: Application developers write logic for CRUD (Create, Read, Update,
Delete) operations, ensuring that application’s data is synchronized with the database.
• Query Optimization: Developers write efficient queries to retrieve and manipulate data
for better application performance.
• Tools: Developers use SQL, programming languages (e.g., Java, Python, C#), and
Frameworks (e.g., Django, Spring Boot) to interact with databases.
20
Database Designers
• Database designers are responsible for identifying data to be
stored in the database and for choosing appropriate structures to
represent and store this data.
• Database designers are responsible to communicate with all
prospective database users in order to understand their
requirements and to create design that meets these requirements.
• Database designers typically interact with each potential group of
users and develop views of the database that meet the data and
processing requirements of these groups.
• The final database design must be capable of supporting the
requirements of all user groups.
21
End Users
• End users are the individuals who interact with the database to perform
everyday tasks, such as querying and reporting.
Types of End Users:
• Casual users: End users who occasionally interact with the system. They
typically use predefined reports or forms.
• Naive users: Users who do not need to understand the underlying
database structure. They interact with the database via front-end
applications, forms, or reports (e.g., employees accessing data from a
payroll system).
• Sophisticated users: Experienced users who may use SQL or other tools
to directly interact with the database. They write their own queries and
manage data.
22
Advantages of Database
• Data redundancy control
• Data integrity
• Data consistency
• Optimized Querying
• Complex queries
• Data access control
• Data encryption
• Logical data independence
• Physical data independence
• Concurrent data access
• Transaction management
• Data backup
• Data recovery
• Improved decision making
• Horizontal and vertical scaling
• Adaptability
• Normalization
• Avoid anomalies
23
Data Models
• A data model is a collection of concepts that can be
used to describe the structure of a database (data
types, relationships, and constraints that apply to the
data).
• A data model determines the logical structure of a
database that helps to find possible design issues
before implementing and deploying the database.
• Data Models are classified as conceptual, Logical and
Physical
24
Data Model: Conceptual
• Conceptual modeling is the creative and abstract phase
(groundwork for the database).
• Conceptual data models use concepts such as entities,
relationships and attributes.
• Entity: real world concept – employee, Projec,t customer, order
• Relationship: A relationship among two or more entities represents an
association among two or more entities – Works on b/w Employee and Project
Super Market
Entities:
Customers,
Products,
Orders
Relationships:
Customers place
Orders for
Products
Attributes:
Product name,
Customer addresses,
Order date
Hospital Mgmt
Entities:
Patients,
Doctors,
Appointments
Relationships:
Patients have
Appointments
with Doctors
Attributes:
Patient name,
Doctor specialization,
Appointment time
25
Data Model: Logical
• Logical relational modeling bridges the gap between abstract
concepts and concrete database structures.
• Entity-to-Table Mapping
• Relationships
• Keys
Library Mgmt
Tables:
Books,
Authors,
Borrowers
Relationships:
Borrowers
borrow Books
Keys:
ISBN (Books),
Author ID (Authors),
Borrower ID (Borrowers)
26
Data Model: Physical
• Physical modeling transforms logical model into a tangible
database structure that resides on disk (Data types, constraints,
indexes, views).
• Creating the Physical Schema
• Optimizing Performance
• Ensuring Security
Tables: “Books”, “Authors”, “Borrowers”
Columns: Book title, Author name, ISBN, Borrower ID
Constraints: Primary keys, foreign keys
Indexes: On book titles, author names
Views: Borrowed books view
Tables: “Products”, “Categories”, “Orders”
Columns: Product name, Category ID, Order details
Constraints: Primary keys, foreign keys
Indexes: On product names, order IDs
Views: Top-selling products view
27
Data Models: Categories
• Entity
• Attribute
• Relationship among two or more entities
 Entity-Relationship model
• Relational data model
• Object data model
• Hierarchical
• Physical data models
28
Data Model: Categories
Entity :
Represents a real-world object
or concept
Attribute:
Represents some property of
interest
29
Data Model : Relationship
29
Relationship:
Association between
two entity types.
Student takes Courses
Customers buys Products
M N
30
Relational model
• Data are organized in two dimensional tables (relations)
• Tables are related to each other
• Relational Database Management System (RDBMS) are more common model used
31
31
Object Data Model
32
32
33
33
34
Hierarchical model
• Data are organized in an upside down tree
• Each entity has one parent and many children
• Old and not used now
35
Network model
• Entities are organized in a graph
• Entities can be accessed through several paths
• Old and not used
36
DBA
Staff
Sophisticated
Users
Application
Programmers
Naïve
Users
DDL
Commands
DDL Commands
1. CREATE
2. ALTER
3. DROP
4. TRUNCATE
5. RENAME
DCL
Commands
DCL Commands
1. GRANT
2. REVOKE
Interactive
Queries
Appl. Pgms.
Precompiler
Host Language
compiler
DDL
Compiler
Query
Compiler
DML
Commands
DML Commands
1. SELECT
2. INSERT
3. DELETE
4. UPDATE
5. LOCK
Compiled
Transactions
DML
Compiler
Data
Dictio
nary
Run-time DB
processor
Concurrency control /
Backup / Recovery
Stored Data Manager
Stored Database
Database System Environment
37
DDL: Data Definition Language
•CREATE
•ALTER
•DROP
•RENAME
•TRUNCATE
38
CREATE
CREATE TABLE table_name
(
column1 datatype constraints,
column2 datatype constraints,
...
columnN datatype constraints
);
CREATE USER user_name IDENTIFIED BY 'password';
CREATE DATABASE databasename;
39
CREATE TABLE in Oracle
40
CREATE
41
DDL: Create
CREATE TABLE CUSTOMER1(
ID Number(2),
NAME NVARCHAR2 (20),
AGE INT,
ADDRESS NVARCHAR2 (30) ,
SALARY DECIMAL (10, 2)
);
create table cust_temp as
select id, name from
customer1;
CREATE TABLE STUDENT2 (
ID INT NOT NULL,
NAME VARCHAR(20) NOT NULL,
AGE INT NOT NULL,
ADDRESS CHAR (25),
PRIMARY KEY (ID) );
42
ALTER
43
DDL: Alter
• ALTER TABLE table_name ADD column_name datatype;
• ALTER TABLE table_name DROP COLUMN column_name;
• ALTER TABLE table_name MODIFY COLUMN column_name
datatype;
• ALTER TABLE table_name MODIFY column_name datatype NOT
NULL;
44
ALTER
45
DROP
46
DDL Command: DROP & Rename
• DROP is used to delete the table.
Drop table student;
•Rename: Renames the table
Rename student1 to student2;
47
DDL Command: TRUNCATE
• TRUNCATE TABLE statement is used to remove all records from
a table.
• Syntax:
 TRUNCATE TABLE table_name;
• TRUNCATE TABLE customer1;
48
Data Manipulation Language
DML:
 INSERT
 UPDATE
 DELETE
 SELECT
49
DML Example: Insert
insert into customer1
values(90, 'Codd',60,'San Fransisco',
150000);
insert into customer1 values(&id,
'&naame',&age,'&address',&salary);
50
DML: Insert
• INSERT INTO EMPLOYEE (
EMP_NAME,EMP_ID,EMP_DEPT,EMP_DOJ,EMP_DESG,EMP_SAL)
VALUES('forouzan', 13, 'ece',TO_DATE('01/01/2002',
'DD/MM/YYYY'), 'Asstmgr', 22222.44)
• INSERT INTO EMPLOYEE (
EMP_NAME,EMP_ID,EMP_DEPT,EMP_DOJ,EMP_DESG,EMP_SAL)
VALUES('Tanenbaum', 14, 'eee',TO_DATE('01/01/2003',
'DD/MM/YYYY'), 'Author', 111111.44)
51
Example: DML commands
Select the data from the Employee table
SELECT * FROM EMPLOYEE
Update a record in the Employee table
UPDATE Employee set EMP_ID=18, Emp_Dept='ME‘
WHERE Emp_name='henry korth';
Delete a record in the Employee table
DELETE FROM Employee WHERE Emp_name='Henry Korth' AND
Emp_Dept='ME';
52
DCL: Data Control Language
• GRANT : used to grant or give the privileges.
• REVOKE : used to avoid or object the privileges.
TCL: Transaction Control Language
• COMMIT: used to save the data permanently.
• ROLLBACK : Used to revert changes in the transactions since the
last commit or rollback command was issued
53
Grant & Revoke commands
create user korth identified by henry
 Connect as system/ora10g
GRANT SELECT, INSERT, UPDATE, DELETE ON Cust_temp TO
korth;
REVOKE DELETE ON Customer1 FROM korth;
55
DCL: Commit
DELETE FROM CUSTOMERS
WHERE AGE = 25;
SQL> COMMIT;
56
Rollback
• ROLLBACK command is the transactional command used to
undo transactions that have not already been saved to the
database.
• This command can only be used to undo transactions since
the last COMMIT or ROLLBACK command was issued.
• DELETE FROM CUSTOMERS WHERE AGE = 25;
• SQL> ROLLBACK;
57
Student
Std_ID Name
Addr
Sec
DoB
Std_ID Name Addr Sec DoB
239X1A05X
Y
Sree Sanfransisco A 01/01/1999
239X1A05X
Z
Sri Germany B 01/01/2000
. . . . . . . . . . . . . . .
. . . . . . . . . . . . . . .
ER Model Relational Model
Entity Relationship Model
represents the overall logical structure of a database.
The E-R data model employs three basic concepts: entity sets,
relationship sets, and attributes
58
Entity, Entity Sets
• Entity: Real-world object distinguishable from other
objects.
• An entity is described (in DB) using a set of attributes.
• Entity Set: A collection of similar entities.
E.g., all employees.
 All entities in an entity set have the same set of attributes.
 Each entity set has a key.
 Each attribute has a domain.
59
Identify Entity and Entity Sets
Loan
L_No Amt
Customer
Cust_id Name Street city
Entity
Entity Sets
E1
E2
E3
.
.
.
En
60
Entity, Entity Set
61
Relationship Sets
• Relationship: Association among two or more
entities.
A relationship set is a mathematical relation among
n  2 entities, each taken from entity sets
{(e1, e2, … en) | e1  E1, e2  E2, …, en  En}
where (e1, e2, …, en) is a relationship
 Example: (Hayes, A-102)  depositor
62
Relationship Set
63
Example1: Relationship Set
Student
Rollno
Name
Addr
Grade
Course
Courseid C_Name
Enrolled
in
64
Example2: Relationship Set
65
Attributes
•An entity is represented by a set of attributes,
that is descriptive properties possessed by all
members of an entity set.
Example:
customer = (customer_id, customer_name, customer_street,
customer_city )
loan = (loan_number, amount )
66
Types of Attributes
Types of
Attributes
Simple
Composite
Single
Valued
Derived
Multi
valued
67
Attribute types
• Simple : Attribute is simple, if its value can not be divided into subparts.
For example Std_ID, Grade.
• Composite : Attribute is composite, if its value can be divided into
subparts. Ex: Name: First Name; Middle Name; Last Name
Address: H.No; street; city; pincode
• Single-valued : Attribute is a single-valued, if it has only one value for a
particular entity. PassportNo.
• Multivalued : Attribute is multivalued, if it has a set of values for a
particular entity. Ex: Phonenumber
• Derived: Attribute is a derived, if its value can be derived from the
values of other related attributes or entities. Ex: Age can be derived
based on dob
68
Identify Simple attributes
Student
RollNo
Sem
Grade
Simple Attributes
RollNo
Sem
Grade
value can not be divided into subparts
69
Identify the type of attribute
Composite Attribute
Address Street,city,country,state
Name  F_name,M_name,L-Name
value can be divided into subparts
70
Identify the type of attribute
value can be divided into subparts
Composite
Attribute
Address
71
Single & Multivalued attributes
only one value for a particular entity: Single Valued
set of values for a particular entity: Multivalued attribute
72
Derived Attribute
Value can be derived from the values of other related attributes
Grade
73
ER Diagram Notations
_________
Key
attribute
Derived
attribute
74
Specialization
• An entity is divided into sub-entities based on their
characteristics.
• Process of designating sub groupings with in an entity set is called
specialization.
• Represented as IS A relationship to represent specialization.
• IS A relationship may also be referred as super class-subclass
relationship
• Example: Person IS A Employee
 Person IS A Customer
 Employee IS A teller
75
Top
Down
Appro
ach
Specialization
76
Generalization
• Two lower level entities combine to form a higher level entity.
• Process of extracting common properties from a set of entities
and create a generalized entity from it
• The design process may also proceed in a bottom-up manner,
in which multiple entity sets are synthesized into a higher-level
entity set on the basis of common features.
77
Generalization
78
ER Diagram: Example
• Design and create University Library Database using ER
diagram
79
Entities: University Database Table
•Books
•Types
•Authors
•Students
•Borrows
80
Attributes
Authors
Authorid
Name
Surname
Books
Bookid
Name
Pagecount
sem
Authorid
typeid
Borrows
Borrowid
Studentid
Bookid
Takendate
Broughtdate
Students
Studentid
Name
Surname
Birthdate
Gender
Class
sem
Types
Typeid
Name
81
Books
Types
Authors
Students
Borrows
Category
Issued to
Lending
Authored
by
Authorid
name
surname
name
bookid
borrowwid
studneti
d
name
typeid
studenti
d name
surname
birthdate
gender
bookid
takendate
Broughtdate
pageco
unt
sem
authorid typeid
82
Table definitions
Authors
Authorid Int ; Primary key
Name Varchar(30)
Surname Varchar(20)
Books
Bookid Int; Primary Key
title Varchar(40)
Pagecount Int
sem Int
Authorid Int
typeid Int
Types
Typeid Int; PK
Name Varchar(20)
83
Table definitions
Borrows
Borrowid Int; Primary key
Studentid Int
Bookid Int
Takendate Date
Broughtdate Date
Students
Studentid Int; Primary key
Name Varchar(30)
Surname Varchar(30)
Birthdate Date
Gender Varchar(6)
Class Varchar(5)
sem int
84
ER Diagram: Univ. Lib. DB
• Books: bookid,title, pagecount, sem, authorid, typeid
• Borrows: borrowid,studentid,bookid,issuedate,returndate
• Authors: Authorid, Name, Surname
• Students: studentid,stname,surname,dob,gender,class,sem
• Types: typeid, name
85
Books
Types
Authors
Students
Borrow
s
Category
Issued to
Lending
Authore
d by
Authori
d name
surnam
e
name
bookid
borrowwi
d
studneti
d
name
typeid
studenti
d name
surname
birthdat
e
gender
bookid
takendate
Broughtdate
pagec
ount
sem
authori
d
typeid
ERD
86
Schema Diagram: ULD
Authors
Authorid
Name
Surname
Books
Bookid
Name
Pagecount
sem
Authorid
typeid
Borrows
Borrowid
Studentid
Bookid
Issuedate
returndate
Students
Studentid
Name
Surname
dob
Gender
Class
sem
Types
Typeid
Name
87
ERD: Bank Database
Management System
88
Relational Model
• The relational model represents the database as a collection of
relations. Informally, each relation resembles a table of values.
• When a relation is thought of as a table of values, each row in the table
represents a collection of related data values.
• A row represents a fact that typically corresponds to a real-world entity or
relationship.
• In the formal relational model terminology, a row is called a tuple, a
column header is called an attribute, and the table is called a relation.
• The data type describing the types of values that can appear in each column is
represented by a domain of possible values
89
Relational Database Concepts
• Relation: made up of 2 parts:
 Instance : a table, with rows and columns.
#Rows = cardinality, #fields = degree / arity.
 Schema : specifies name of relation, plus name and domain (type) of
each column (attribute).
• Can think of a relation as a set of rows or tuples (i.e., all rows
are distinct), where each tuple has the same arity as the
relation schema.
• Relational database: a set of relations, each with distinct name.
• Relational DB schema: set of schemas of relations in the DB.
• Relational DB instance: set of relation instances in the DB.
90
DEFINITION SUMMARY
Informal Terms Formal Terms
Table Relation
Column Attribute/Domain
Row Tuple
Values in a column Domain
Table Definition Schema of a Relation
Populated Table State or Instance
91
Example of a Relation
sid name login age gpa
53666 Jones jones@cs 18 3.4
53688 Smith smith@eecs 18 3.2
53650 Smith smith@math 19 3.8
Schema: Students(sid, name, login,age, gpa).
 Cardinality = 3, arity = 5, all rows distinct.
Instance:
92
Concepts of Domain
• A domain D is a set of atomic values. By atomic, it means
that each value in the domain is indivisible as far as the
formal relational model is concerned.
• A domain is to specify a data type from which the data
values forming the domain are drawn.
• A data type or format is also specified for each domain.
• A relation (or relation state) r(R) is a mathematical relation of degree n on the domains dom(A1),
dom(A2), ..., dom(An), which is a subset of the Cartesian product (denoted by ×) of the domains that
define R: r(R) ⊆ (dom(A1) × dom(A2) × ... × dom(An))
93
Creating Relations in SQL
• Create the Students
relation.
• Observe that the type (domain)
of each field is specified, and
enforced by the DBMS
whenever tuples are added or
modified.
• As another example, the
Enrolled table holds
information about courses
that students take.
CREATE TABLE Students
(sid VARCHAR(20),
name VARCHAR(20),
login: CHAR(10),
age: INTEGER,
gpa: NUMBER
CREATE TABLE Enrolled
(sid VARCHAR(20),
cid VARCHAR(20),
grade VARCHAR(2))
94
Concept of Domain
A domain has a logical definition: e.g.,
“phone_numbers” are the set of 10 digit phone numbers
A domain may have a data-type or a format defined for
it. phone_numbers may have a format:
(ddd)-ddd-dddd where each d is a decimal digit.
E.g., Dates have various formats such as monthname,
date, year or yyyy-mm-dd, or dd mm,yyyy etc.
An attribute designates the role played by the domain.
E.g., the domain Date may be used to define attributes
“Invoice-date” and “Payment-date”.
95
Relational Integrity Constraints
• Constraints are conditions that must hold on all
valid relation instances. There are four main types
of constraints:
1. Domain constraints
2. Key constraints
3. Entity integrity constraints
4. Referential integrity constraints
97
Domain Constraints
• When you define a domain for an attribute, you are establishing
the constraint that all values for that attribute must belong to that
domain.
Domain Constraint
=
data type(integer / character/date / time / etc.)
+
Constraints(NOT NULL / UNIQUE / PRIMARY KEY / FOREIGN KEY /
CHECK / DEFAULT)
98
Key Constraints
• A key constraint refers to a set of rules applied to one or more
columns in a database table to ensure the uniqueness and integrity
of data.
• Keys are used to uniquely identify rows in a table.
Primary Key Constraint
Unique Constraint
Foreign Key Constraint
99
Entity Constraints
• Entity Integrity Constraint emphasizes that no attribute of a
Primary Key should contain null values.
100
Referential Constraints
• Referential integrity in a database is a crucial concept ensuring
data consistency among related tables through primary and
foreign keys.
• The referential integrity constraint is established when a foreign
key references the primary key of another table, requiring the
referencing attribute to be a subset of the referred attribute.
101
Data types (Oracle)
Built-in Data Types
1. CHARACTER
2. NUMBER
3. LONG AND RAW
4. DATETIME
5. LARGE_OBJECT
6. ROWID
ORACLE Data Types
1. Built-in Data Types
2. ANSI Supported DT
3. User Defined DT
4. Oracle Supplied DT
102
Data types (Oracle)
Built-in Data Types
1. CHARACTER
2. NUMBER
3. LONG AND RAW
4. DATETIME
5. LARGE_OBJECT
6. ROWID
ORACLE Data Types
1. Built-in Data Types
2. ANSI Supported DT
3. User Defined DT
4. Oracle Supplied DT
103
Data types (Oracle)
Built-in Data Types
1. CHARACTER
2. NUMBER
3. LONG AND RAW
4. DATETIME
5. LARGE_OBJECT
6. ROWID
ORACLE Data Types
1. Built-in Data Types
2. ANSI Supported DT
3. User Defined DT
4. Oracle Supplied DT
104
Data types in Oracle
Built-in Data Types
1. CHARACTER
2. NUMBER
3. LONG AND RAW
4. DATETIME
5. LARGE_OBJECT
6. ROWID
ORACLE Data Types
1. Built-in Data Types
2. ANSI Supported DT
3. User Defined DT
4. Oracle Supplied DT
105
Data types in Oracle
Built-in Data Types
1. CHARACTER
2. NUMBER
3. LONG AND RAW
4. DATETIME
5. LARGE_OBJECT
6. ROWID
ORACLE Data Types
1. Built-in Data Types
2. ANSI Supported DT
3. User Defined DT
4. Oracle Supplied DT
106
Data types in Oracle
Built-in Data Types
1. CHARACTER
2. NUMBER
3. LONG AND RAW
4. DATETIME
5. LARGE_OBJECT
6. ROWID
ORACLE Data Types
1. Built-in Data Types
2. ANSI Supported DT
3. User Defined DT
4. Oracle Supplied DT
107
Data types in Oracle
Built-in Data Types
1. CHARACTER
2. NUMBER
3. LONG AND RAW
4. DATETIME
5. LARGE_OBJECT
6. ROWID
ORACLE Data Types
1. Built-in Data Types
2. ANSI Supported DT
3. User Defined DT
4. Oracle Supplied DT
108
ANSI_supported_datatypes
109

Database management systems Lecture Notes

  • 1.
    DATABASE MANAGEMENT SYSTEMS Dr. C.Sreedhar Professor, CSE Dept., G. Pulla Reddy Engineering College, Kurnool *Some of the images and contents are copied from Internet sources
  • 2.
    2 Unit I • Introduction:Database system, Characteristics (Database Vs File System), Database Users, Advantages of Database systems, Database applications. • Brief introduction of different Data Models; Database system structure, environment. • Entity Relationship Model: Introduction, Representation of entities, attributes, entity set, relationship, relationship set, constraints, specialization, generalization using ER Diagrams.
  • 3.
    3 Unit II • RelationalModel: Introduction to relational model, concepts of domain, attribute, tuple, relation, importance of null values, constraints (Domain, Key constraints, integrity constraints) and their importance. • BASIC SQL: Simple Database schema, data types, table definitions (create, alter), • DML operations (insert, delete, update).
  • 4.
    4 DBMS: Introduction 1. Data 2.Information 3. Database 4. DBMS 5. Database System 1. Raw facts 2. Processed data 3. Collection of related data. 4. Software that manages and controls access to the database 5. Collection of application programs that interact with the database along with the DBMS and the database itself.
  • 5.
    5 Database vs. FileSystem • The database and the file system are two distinct methods of storing and managing data. • While they both handle the storage of information, they differ in their architecture, functionality, and the types of tasks they are optimized for. • File System File-based systems were an early attempt to computerize the manual filing system. • Examples of File system (Decades ago): Banking, Schools, Hospitals
  • 6.
    6 Database Vs. FileSystem Definition structured system for storing, managing, and retrieving data using specialized software. Used by operating systems to store, organize, and manage files on a storage device. Structure Data is stored in tables, records, and fields, with relationships between different tables. Data is stored as individual files in a directory hierarchy. Each file is independent. Data Integrity A database enforces integrity constraints to ensure data consistency and accuracy. File systems do not inherently provide mechanisms for enforcing data integrity. Data consistency is left to the application level.
  • 7.
    7 Database vs. FileSystem Data Retrieval Uses SQL to retrieve and manipulate data and supports complex queries with filtering, sorting, and joining data. Data retrieval is typically done by opening file and reading its contents. Complex queries and relationships between data are not inherently supported. Scalability Databases are designed to scale efficiently with large amounts of data queries. File systems can manage large files but do not efficiently handle large-scale databases with relational or complex data models. Data Redundancy Databases are optimized to minimize redundancy through normalization (breaking data into smaller related tables). In file systems, data redundancy can occur as files are copied, and relationships between different files are not managed.
  • 8.
    8 Database vs. Filesystem: Use Cases • Database:  Managing customer orders and inventory in an e-commerce application.  Storing employee information, such as payroll, roles, and attendance in an HR system.  Banking transactions in a financial system where data integrity, relationships, and querying are crucial. • File System:  Storing documents, media files, and logs.  Managing configuration files or text files used by an application.  Storing backup copies of data or files for long-term archiving.
  • 9.
    9 Database vs. FileSystem • A Database is a highly structured system designed for storing, managing, and querying large amounts of related data, while a File System is a basic method of storing and accessing unstructured data files. • Databases offer advanced features such as data integrity, concurrency control, and complex querying, making them ideal for managing large, structured datasets. • File Systems are simpler and more suited for managing documents, images, or other types of unstructured data where relationships and advanced querying are not required.
  • 10.
    10 Limitations of File-BasedApproach • Data Redundancy and Inconsistency • Difficulty in Data Retrieval • Separation and isolation of data • Duplication of data • Data Integrity Issues • Concurrency Issues • Scalability Problems • Incompatible file formats
  • 11.
    11 Database Management System(DBMS) • DBMS contains information about particular enterprise  Collection of interrelated data  Set of programs to access the data  Environment that is both convenient and efficient to use • Database Applications:  Banking: transactions  Airlines: reservations, schedules  Universities: registration, grades  Sales: customers, products, purchases  Online retailers: order tracking, customized recommendations  Manufacturing: production, inventory,orders,supply chain  Human resources: employee records, salaries, tax deductions
  • 12.
    12 Drawbacks of usingfile systems • Data redundancy and inconsistency  Multiple file formats, duplication in different files • Difficulty in accessing data  Need to write new program to carry out each new task • Data isolation  Multiple files and formats • Integrity problems  Integrity constraints (e.g., account balance > 0)  Hard to add new constraints or change existing ones
  • 13.
    13 Drawbacks of usingfile systems contd.. • Atomicity of updates  Failures may leave database in an inconsistent state with partial updates carried out  Example: Transfer of funds from one account to another should either complete or not happen at all • Concurrent access by multiple users  Concurrent access needed for performance  Uncontrolled concurrent accesses can lead to inconsistencies • Example: Two people reading a balance (say 100) and updating it by withdrawing money (say 50 each) at the same time • Security problems  Hard to provide user access to some, but not all, data Database systems offer solutions to all the above problems
  • 14.
    14 14 Database Management System DBMSmanages data resources like an operating system manages hardware resources DBMS Database containing centralized shared data Application #1 Application #2 Application #3
  • 15.
  • 16.
    16 Database Users • DatabaseUsers: Individuals or applications that interact with the database to perform operations like querying, updating, and managing the data. • Data Administrator • Database Administrator • Database Designers
  • 17.
    17 Data Administrator • DataAdministrator (DA) is responsible for the management of the data resource, including database planning; development and maintenance of standards, policies and procedures; and conceptual/logical database design. • The DA consults with and advises senior managers, ensuring that the direction of database development will ultimately support corporate objectives
  • 18.
    18 Database Administrator • TheDatabase Administrator (DBA) is responsible for the overall management and maintenance of the database system. Responsibilities: • Database design: Designing database schema, including tables, relationships, constraints. • Database creation and configuration: Installing, configuring, and maintaining the DBMS. • Security Mgmt.: Managing user access, privileges, roles, and ensuring data security. • Backup and recovery: Ensuring that data is regularly backed up & recovered upon failure. • Performance tuning: Monitoring database performance and optimizing queries, indexing, and storage. • Data migration: Migrating data from one system to another or upgrading DBMS versions. • Ensuring data integrity and consistency: Enforcing data constraints (e.g., primary keys, foreign keys, etc.) and ensuring the consistency of data. • Tools: SQL Server Management Studio, Oracle Enterprise Manager, MySQL Workbench.
  • 19.
    19 Application Developers • ApplicationDevelopers design and develop software applications that interact with the database. These applications can be for business operations, analytics, or other purposes. Responsibilities: • Database design: Application developers work with the DBA to ensure the application’s database design meets the application's needs. • Database integration: Writing code that allows application to interact with the database using SQL queries and other database access methods. • Data Manipulation: Application developers write logic for CRUD (Create, Read, Update, Delete) operations, ensuring that application’s data is synchronized with the database. • Query Optimization: Developers write efficient queries to retrieve and manipulate data for better application performance. • Tools: Developers use SQL, programming languages (e.g., Java, Python, C#), and Frameworks (e.g., Django, Spring Boot) to interact with databases.
  • 20.
    20 Database Designers • Databasedesigners are responsible for identifying data to be stored in the database and for choosing appropriate structures to represent and store this data. • Database designers are responsible to communicate with all prospective database users in order to understand their requirements and to create design that meets these requirements. • Database designers typically interact with each potential group of users and develop views of the database that meet the data and processing requirements of these groups. • The final database design must be capable of supporting the requirements of all user groups.
  • 21.
    21 End Users • Endusers are the individuals who interact with the database to perform everyday tasks, such as querying and reporting. Types of End Users: • Casual users: End users who occasionally interact with the system. They typically use predefined reports or forms. • Naive users: Users who do not need to understand the underlying database structure. They interact with the database via front-end applications, forms, or reports (e.g., employees accessing data from a payroll system). • Sophisticated users: Experienced users who may use SQL or other tools to directly interact with the database. They write their own queries and manage data.
  • 22.
    22 Advantages of Database •Data redundancy control • Data integrity • Data consistency • Optimized Querying • Complex queries • Data access control • Data encryption • Logical data independence • Physical data independence • Concurrent data access • Transaction management • Data backup • Data recovery • Improved decision making • Horizontal and vertical scaling • Adaptability • Normalization • Avoid anomalies
  • 23.
    23 Data Models • Adata model is a collection of concepts that can be used to describe the structure of a database (data types, relationships, and constraints that apply to the data). • A data model determines the logical structure of a database that helps to find possible design issues before implementing and deploying the database. • Data Models are classified as conceptual, Logical and Physical
  • 24.
    24 Data Model: Conceptual •Conceptual modeling is the creative and abstract phase (groundwork for the database). • Conceptual data models use concepts such as entities, relationships and attributes. • Entity: real world concept – employee, Projec,t customer, order • Relationship: A relationship among two or more entities represents an association among two or more entities – Works on b/w Employee and Project Super Market Entities: Customers, Products, Orders Relationships: Customers place Orders for Products Attributes: Product name, Customer addresses, Order date Hospital Mgmt Entities: Patients, Doctors, Appointments Relationships: Patients have Appointments with Doctors Attributes: Patient name, Doctor specialization, Appointment time
  • 25.
    25 Data Model: Logical •Logical relational modeling bridges the gap between abstract concepts and concrete database structures. • Entity-to-Table Mapping • Relationships • Keys Library Mgmt Tables: Books, Authors, Borrowers Relationships: Borrowers borrow Books Keys: ISBN (Books), Author ID (Authors), Borrower ID (Borrowers)
  • 26.
    26 Data Model: Physical •Physical modeling transforms logical model into a tangible database structure that resides on disk (Data types, constraints, indexes, views). • Creating the Physical Schema • Optimizing Performance • Ensuring Security Tables: “Books”, “Authors”, “Borrowers” Columns: Book title, Author name, ISBN, Borrower ID Constraints: Primary keys, foreign keys Indexes: On book titles, author names Views: Borrowed books view Tables: “Products”, “Categories”, “Orders” Columns: Product name, Category ID, Order details Constraints: Primary keys, foreign keys Indexes: On product names, order IDs Views: Top-selling products view
  • 27.
    27 Data Models: Categories •Entity • Attribute • Relationship among two or more entities  Entity-Relationship model • Relational data model • Object data model • Hierarchical • Physical data models
  • 28.
    28 Data Model: Categories Entity: Represents a real-world object or concept Attribute: Represents some property of interest
  • 29.
    29 Data Model :Relationship 29 Relationship: Association between two entity types. Student takes Courses Customers buys Products M N
  • 30.
    30 Relational model • Dataare organized in two dimensional tables (relations) • Tables are related to each other • Relational Database Management System (RDBMS) are more common model used
  • 31.
  • 32.
  • 33.
  • 34.
    34 Hierarchical model • Dataare organized in an upside down tree • Each entity has one parent and many children • Old and not used now
  • 35.
    35 Network model • Entitiesare organized in a graph • Entities can be accessed through several paths • Old and not used
  • 36.
    36 DBA Staff Sophisticated Users Application Programmers Naïve Users DDL Commands DDL Commands 1. CREATE 2.ALTER 3. DROP 4. TRUNCATE 5. RENAME DCL Commands DCL Commands 1. GRANT 2. REVOKE Interactive Queries Appl. Pgms. Precompiler Host Language compiler DDL Compiler Query Compiler DML Commands DML Commands 1. SELECT 2. INSERT 3. DELETE 4. UPDATE 5. LOCK Compiled Transactions DML Compiler Data Dictio nary Run-time DB processor Concurrency control / Backup / Recovery Stored Data Manager Stored Database Database System Environment
  • 37.
    37 DDL: Data DefinitionLanguage •CREATE •ALTER •DROP •RENAME •TRUNCATE
  • 38.
    38 CREATE CREATE TABLE table_name ( column1datatype constraints, column2 datatype constraints, ... columnN datatype constraints ); CREATE USER user_name IDENTIFIED BY 'password'; CREATE DATABASE databasename;
  • 39.
  • 40.
  • 41.
    41 DDL: Create CREATE TABLECUSTOMER1( ID Number(2), NAME NVARCHAR2 (20), AGE INT, ADDRESS NVARCHAR2 (30) , SALARY DECIMAL (10, 2) ); create table cust_temp as select id, name from customer1; CREATE TABLE STUDENT2 ( ID INT NOT NULL, NAME VARCHAR(20) NOT NULL, AGE INT NOT NULL, ADDRESS CHAR (25), PRIMARY KEY (ID) );
  • 42.
  • 43.
    43 DDL: Alter • ALTERTABLE table_name ADD column_name datatype; • ALTER TABLE table_name DROP COLUMN column_name; • ALTER TABLE table_name MODIFY COLUMN column_name datatype; • ALTER TABLE table_name MODIFY column_name datatype NOT NULL;
  • 44.
  • 45.
  • 46.
    46 DDL Command: DROP& Rename • DROP is used to delete the table. Drop table student; •Rename: Renames the table Rename student1 to student2;
  • 47.
    47 DDL Command: TRUNCATE •TRUNCATE TABLE statement is used to remove all records from a table. • Syntax:  TRUNCATE TABLE table_name; • TRUNCATE TABLE customer1;
  • 48.
    48 Data Manipulation Language DML: INSERT  UPDATE  DELETE  SELECT
  • 49.
    49 DML Example: Insert insertinto customer1 values(90, 'Codd',60,'San Fransisco', 150000); insert into customer1 values(&id, '&naame',&age,'&address',&salary);
  • 50.
    50 DML: Insert • INSERTINTO EMPLOYEE ( EMP_NAME,EMP_ID,EMP_DEPT,EMP_DOJ,EMP_DESG,EMP_SAL) VALUES('forouzan', 13, 'ece',TO_DATE('01/01/2002', 'DD/MM/YYYY'), 'Asstmgr', 22222.44) • INSERT INTO EMPLOYEE ( EMP_NAME,EMP_ID,EMP_DEPT,EMP_DOJ,EMP_DESG,EMP_SAL) VALUES('Tanenbaum', 14, 'eee',TO_DATE('01/01/2003', 'DD/MM/YYYY'), 'Author', 111111.44)
  • 51.
    51 Example: DML commands Selectthe data from the Employee table SELECT * FROM EMPLOYEE Update a record in the Employee table UPDATE Employee set EMP_ID=18, Emp_Dept='ME‘ WHERE Emp_name='henry korth'; Delete a record in the Employee table DELETE FROM Employee WHERE Emp_name='Henry Korth' AND Emp_Dept='ME';
  • 52.
    52 DCL: Data ControlLanguage • GRANT : used to grant or give the privileges. • REVOKE : used to avoid or object the privileges. TCL: Transaction Control Language • COMMIT: used to save the data permanently. • ROLLBACK : Used to revert changes in the transactions since the last commit or rollback command was issued
  • 53.
    53 Grant & Revokecommands create user korth identified by henry  Connect as system/ora10g GRANT SELECT, INSERT, UPDATE, DELETE ON Cust_temp TO korth; REVOKE DELETE ON Customer1 FROM korth;
  • 54.
    55 DCL: Commit DELETE FROMCUSTOMERS WHERE AGE = 25; SQL> COMMIT;
  • 55.
    56 Rollback • ROLLBACK commandis the transactional command used to undo transactions that have not already been saved to the database. • This command can only be used to undo transactions since the last COMMIT or ROLLBACK command was issued. • DELETE FROM CUSTOMERS WHERE AGE = 25; • SQL> ROLLBACK;
  • 56.
    57 Student Std_ID Name Addr Sec DoB Std_ID NameAddr Sec DoB 239X1A05X Y Sree Sanfransisco A 01/01/1999 239X1A05X Z Sri Germany B 01/01/2000 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . ER Model Relational Model Entity Relationship Model represents the overall logical structure of a database. The E-R data model employs three basic concepts: entity sets, relationship sets, and attributes
  • 57.
    58 Entity, Entity Sets •Entity: Real-world object distinguishable from other objects. • An entity is described (in DB) using a set of attributes. • Entity Set: A collection of similar entities. E.g., all employees.  All entities in an entity set have the same set of attributes.  Each entity set has a key.  Each attribute has a domain.
  • 58.
    59 Identify Entity andEntity Sets Loan L_No Amt Customer Cust_id Name Street city Entity Entity Sets E1 E2 E3 . . . En
  • 59.
  • 60.
    61 Relationship Sets • Relationship:Association among two or more entities. A relationship set is a mathematical relation among n  2 entities, each taken from entity sets {(e1, e2, … en) | e1  E1, e2  E2, …, en  En} where (e1, e2, …, en) is a relationship  Example: (Hayes, A-102)  depositor
  • 61.
  • 62.
  • 63.
  • 64.
    65 Attributes •An entity isrepresented by a set of attributes, that is descriptive properties possessed by all members of an entity set. Example: customer = (customer_id, customer_name, customer_street, customer_city ) loan = (loan_number, amount )
  • 65.
    66 Types of Attributes Typesof Attributes Simple Composite Single Valued Derived Multi valued
  • 66.
    67 Attribute types • Simple: Attribute is simple, if its value can not be divided into subparts. For example Std_ID, Grade. • Composite : Attribute is composite, if its value can be divided into subparts. Ex: Name: First Name; Middle Name; Last Name Address: H.No; street; city; pincode • Single-valued : Attribute is a single-valued, if it has only one value for a particular entity. PassportNo. • Multivalued : Attribute is multivalued, if it has a set of values for a particular entity. Ex: Phonenumber • Derived: Attribute is a derived, if its value can be derived from the values of other related attributes or entities. Ex: Age can be derived based on dob
  • 67.
    68 Identify Simple attributes Student RollNo Sem Grade SimpleAttributes RollNo Sem Grade value can not be divided into subparts
  • 68.
    69 Identify the typeof attribute Composite Attribute Address Street,city,country,state Name  F_name,M_name,L-Name value can be divided into subparts
  • 69.
    70 Identify the typeof attribute value can be divided into subparts Composite Attribute Address
  • 70.
    71 Single & Multivaluedattributes only one value for a particular entity: Single Valued set of values for a particular entity: Multivalued attribute
  • 71.
    72 Derived Attribute Value canbe derived from the values of other related attributes Grade
  • 72.
  • 73.
    74 Specialization • An entityis divided into sub-entities based on their characteristics. • Process of designating sub groupings with in an entity set is called specialization. • Represented as IS A relationship to represent specialization. • IS A relationship may also be referred as super class-subclass relationship • Example: Person IS A Employee  Person IS A Customer  Employee IS A teller
  • 74.
  • 75.
    76 Generalization • Two lowerlevel entities combine to form a higher level entity. • Process of extracting common properties from a set of entities and create a generalized entity from it • The design process may also proceed in a bottom-up manner, in which multiple entity sets are synthesized into a higher-level entity set on the basis of common features.
  • 76.
  • 77.
    78 ER Diagram: Example •Design and create University Library Database using ER diagram
  • 78.
    79 Entities: University DatabaseTable •Books •Types •Authors •Students •Borrows
  • 79.
  • 80.
  • 81.
    82 Table definitions Authors Authorid Int; Primary key Name Varchar(30) Surname Varchar(20) Books Bookid Int; Primary Key title Varchar(40) Pagecount Int sem Int Authorid Int typeid Int Types Typeid Int; PK Name Varchar(20)
  • 82.
    83 Table definitions Borrows Borrowid Int;Primary key Studentid Int Bookid Int Takendate Date Broughtdate Date Students Studentid Int; Primary key Name Varchar(30) Surname Varchar(30) Birthdate Date Gender Varchar(6) Class Varchar(5) sem int
  • 83.
    84 ER Diagram: Univ.Lib. DB • Books: bookid,title, pagecount, sem, authorid, typeid • Borrows: borrowid,studentid,bookid,issuedate,returndate • Authors: Authorid, Name, Surname • Students: studentid,stname,surname,dob,gender,class,sem • Types: typeid, name
  • 84.
    85 Books Types Authors Students Borrow s Category Issued to Lending Authore d by Authori dname surnam e name bookid borrowwi d studneti d name typeid studenti d name surname birthdat e gender bookid takendate Broughtdate pagec ount sem authori d typeid ERD
  • 85.
  • 86.
  • 87.
    88 Relational Model • Therelational model represents the database as a collection of relations. Informally, each relation resembles a table of values. • When a relation is thought of as a table of values, each row in the table represents a collection of related data values. • A row represents a fact that typically corresponds to a real-world entity or relationship. • In the formal relational model terminology, a row is called a tuple, a column header is called an attribute, and the table is called a relation. • The data type describing the types of values that can appear in each column is represented by a domain of possible values
  • 88.
    89 Relational Database Concepts •Relation: made up of 2 parts:  Instance : a table, with rows and columns. #Rows = cardinality, #fields = degree / arity.  Schema : specifies name of relation, plus name and domain (type) of each column (attribute). • Can think of a relation as a set of rows or tuples (i.e., all rows are distinct), where each tuple has the same arity as the relation schema. • Relational database: a set of relations, each with distinct name. • Relational DB schema: set of schemas of relations in the DB. • Relational DB instance: set of relation instances in the DB.
  • 89.
    90 DEFINITION SUMMARY Informal TermsFormal Terms Table Relation Column Attribute/Domain Row Tuple Values in a column Domain Table Definition Schema of a Relation Populated Table State or Instance
  • 90.
    91 Example of aRelation sid name login age gpa 53666 Jones jones@cs 18 3.4 53688 Smith smith@eecs 18 3.2 53650 Smith smith@math 19 3.8 Schema: Students(sid, name, login,age, gpa).  Cardinality = 3, arity = 5, all rows distinct. Instance:
  • 91.
    92 Concepts of Domain •A domain D is a set of atomic values. By atomic, it means that each value in the domain is indivisible as far as the formal relational model is concerned. • A domain is to specify a data type from which the data values forming the domain are drawn. • A data type or format is also specified for each domain. • A relation (or relation state) r(R) is a mathematical relation of degree n on the domains dom(A1), dom(A2), ..., dom(An), which is a subset of the Cartesian product (denoted by ×) of the domains that define R: r(R) ⊆ (dom(A1) × dom(A2) × ... × dom(An))
  • 92.
    93 Creating Relations inSQL • Create the Students relation. • Observe that the type (domain) of each field is specified, and enforced by the DBMS whenever tuples are added or modified. • As another example, the Enrolled table holds information about courses that students take. CREATE TABLE Students (sid VARCHAR(20), name VARCHAR(20), login: CHAR(10), age: INTEGER, gpa: NUMBER CREATE TABLE Enrolled (sid VARCHAR(20), cid VARCHAR(20), grade VARCHAR(2))
  • 93.
    94 Concept of Domain Adomain has a logical definition: e.g., “phone_numbers” are the set of 10 digit phone numbers A domain may have a data-type or a format defined for it. phone_numbers may have a format: (ddd)-ddd-dddd where each d is a decimal digit. E.g., Dates have various formats such as monthname, date, year or yyyy-mm-dd, or dd mm,yyyy etc. An attribute designates the role played by the domain. E.g., the domain Date may be used to define attributes “Invoice-date” and “Payment-date”.
  • 94.
    95 Relational Integrity Constraints •Constraints are conditions that must hold on all valid relation instances. There are four main types of constraints: 1. Domain constraints 2. Key constraints 3. Entity integrity constraints 4. Referential integrity constraints
  • 95.
    97 Domain Constraints • Whenyou define a domain for an attribute, you are establishing the constraint that all values for that attribute must belong to that domain. Domain Constraint = data type(integer / character/date / time / etc.) + Constraints(NOT NULL / UNIQUE / PRIMARY KEY / FOREIGN KEY / CHECK / DEFAULT)
  • 96.
    98 Key Constraints • Akey constraint refers to a set of rules applied to one or more columns in a database table to ensure the uniqueness and integrity of data. • Keys are used to uniquely identify rows in a table. Primary Key Constraint Unique Constraint Foreign Key Constraint
  • 97.
    99 Entity Constraints • EntityIntegrity Constraint emphasizes that no attribute of a Primary Key should contain null values.
  • 98.
    100 Referential Constraints • Referentialintegrity in a database is a crucial concept ensuring data consistency among related tables through primary and foreign keys. • The referential integrity constraint is established when a foreign key references the primary key of another table, requiring the referencing attribute to be a subset of the referred attribute.
  • 99.
    101 Data types (Oracle) Built-inData Types 1. CHARACTER 2. NUMBER 3. LONG AND RAW 4. DATETIME 5. LARGE_OBJECT 6. ROWID ORACLE Data Types 1. Built-in Data Types 2. ANSI Supported DT 3. User Defined DT 4. Oracle Supplied DT
  • 100.
    102 Data types (Oracle) Built-inData Types 1. CHARACTER 2. NUMBER 3. LONG AND RAW 4. DATETIME 5. LARGE_OBJECT 6. ROWID ORACLE Data Types 1. Built-in Data Types 2. ANSI Supported DT 3. User Defined DT 4. Oracle Supplied DT
  • 101.
    103 Data types (Oracle) Built-inData Types 1. CHARACTER 2. NUMBER 3. LONG AND RAW 4. DATETIME 5. LARGE_OBJECT 6. ROWID ORACLE Data Types 1. Built-in Data Types 2. ANSI Supported DT 3. User Defined DT 4. Oracle Supplied DT
  • 102.
    104 Data types inOracle Built-in Data Types 1. CHARACTER 2. NUMBER 3. LONG AND RAW 4. DATETIME 5. LARGE_OBJECT 6. ROWID ORACLE Data Types 1. Built-in Data Types 2. ANSI Supported DT 3. User Defined DT 4. Oracle Supplied DT
  • 103.
    105 Data types inOracle Built-in Data Types 1. CHARACTER 2. NUMBER 3. LONG AND RAW 4. DATETIME 5. LARGE_OBJECT 6. ROWID ORACLE Data Types 1. Built-in Data Types 2. ANSI Supported DT 3. User Defined DT 4. Oracle Supplied DT
  • 104.
    106 Data types inOracle Built-in Data Types 1. CHARACTER 2. NUMBER 3. LONG AND RAW 4. DATETIME 5. LARGE_OBJECT 6. ROWID ORACLE Data Types 1. Built-in Data Types 2. ANSI Supported DT 3. User Defined DT 4. Oracle Supplied DT
  • 105.
    107 Data types inOracle Built-in Data Types 1. CHARACTER 2. NUMBER 3. LONG AND RAW 4. DATETIME 5. LARGE_OBJECT 6. ROWID ORACLE Data Types 1. Built-in Data Types 2. ANSI Supported DT 3. User Defined DT 4. Oracle Supplied DT
  • 106.
  • 107.