DBMS Part 1

Download as pdf or txt
Download as pdf or txt
You are on page 1of 7

What is Database

The database is a collection of inter-related data which is used to retrieve, insert and delete the
data efficiently. It is also used to organize the data in the form of a table, schema, views, and
reports, etc.

For example: The college Database organizes the data about the admin, staff, students and
faculty etc.

Using the database, you can easily retrieve, insert, and delete the information.

Database Management System

o Database management system is a software which is used to manage the database. For
example: MySQL, Oracle, etc are a very popular commercial database which is used in
different applications.
o DBMS provides an interface to perform various operations like database creation,
storing data in it, updating data, creating a table in the database and a lot more.
o It provides protection and security to the database. In the case of multiple users, it also
maintains data consistency.

DBMS allows users the following tasks / Applications of DBMS:

o Data Definition: It is used for creation, modification, and removal of definition that
defines the organization of data in the database.
o Data Updation: It is used for the insertion, modification, and deletion of the actual data
in the database.
o Data Retrieval: It is used to retrieve the data from the database which can be used by
applications for various purposes.
o User Administration: It is used for registering and monitoring users, maintain data
integrity, enforcing data security, dealing with concurrency control, monitoring
performance and recovering information corrupted by unexpected failure.

Characteristics of DBMS

o It uses a digital repository established on a server to store and manage the information.
o It can provide a clear and logical view of the process that manipulates data.
o DBMS contains automatic backup and recovery procedures.
o It contains ACID properties which maintain data in a healthy state in case of failure.
o It can reduce the complex relationship between data.
o It is used to support manipulation and processing of data.
o It is used to provide security of data.
o It can view the database from different viewpoints according to the requirements of the
user.

Advantages of DBMS

o Controls database redundancy: It can control data redundancy because it stores all
the data in one single database file and that recorded data is placed in the database.
o Data sharing: In DBMS, the authorized users of an organization can share the data
among multiple users.
o Easily Maintenance: It can be easily maintainable due to the centralized nature of the
database system.
o Reduce time: It reduces development time and maintenance need.
o Backup: It provides backup and recovery subsystems which create automatic backup
of data from hardware and software failures and restores the data if required.
o multiple user interface: It provides different types of user interfaces like graphical
user interfaces, application program interfaces

Disadvantages of DBMS

o Cost of Hardware and Software: It requires a high speed of data processor and large
memory size to run DBMS software.
o Size: It occupies a large space of disks and large memory to run them efficiently.
o Complexity: Database system creates additional complexity and requirements.
o Higher impact of failure: Failure is highly impacted the database because in most of
the organization, all the data stored in a single database and if the database is damaged
due to electric failure or database corruption then the data may be lost forever.

File System: A File Management system is a DBMS that allows access to single files or
tables at a time. In a File System, data is directly stored in a set of files. It contains flat files
that have no relation to other files (when only one table is stored in a single file, then this file
is known as a flat file).
DBMS: A Database Management System (DBMS) is application software that allows users
to efficiently define, create, maintain and share databases. Defining a database involves
specifying the data types, structures and constraints of the data to be stored in the database.
Creating a database involves storing the data on some storage medium that is controlled by
DBMS. Maintaining a database involves updating the database whenever required to evolve
and reflect changes in the Mini world and also generating reports for each change. Sharing a
database involves allowing multiple users to access the database. DBMS also serves as an
interface between the database and end users or application programs. It provides control
access to the data and ensures that data is consistent and correct by defining rules on them.
An application program accesses the database by sending queries or requests for data to the
DBMS. A query causes some data to be retrieved from the database.

Advantages of DBMS over File system:

 Data redundancy and inconsistency: Redundancy is the concept of repetition of


data i.e., each data may have more than a single copy. The file system cannot
control the redundancy of data as each user defines and maintains the needed files
for a specific application to run. There may be a possibility that two users are
maintaining the data of the same file for different applications. Hence changes
made by one user do not reflect in files used by second users, which leads to
inconsistency of data. Whereas DBMS controls redundancy by maintaining a
single repository of data that is defined once and is accessed by many users. As
there is no or less redundancy, data remains consistent.
 Data sharing: The file system does not allow sharing of data or sharing is too
complex. Whereas in DBMS, data can be shared easily due to a centralized
system.
 Data concurrency: Concurrent access to data means more than one user is
accessing the same data at the same time. Anomalies occur when changes made
by one user get lost because of changes made by another user. The file system
does not provide any procedure to stop anomalies. Whereas DBMS provides a
locking system to stop anomalies to occur.
 Data searching: For every search operation performed on the file system, a
different application program has to be written. While DBMS provides inbuilt
searching operations. The user only has to write a small query to retrieve data
from the database.
 Data integrity: There may be cases when some constraints need to be applied to
the data before inserting it into the database. The file system does not provide any
procedure to check these constraints automatically. Whereas DBMS maintains
data integrity by enforcing user-defined constraints on data by itself.
 System crashing: In some cases, systems might have crashed due to various
reasons. It is a bane in the case of file systems because once the system crashes,
there will be no recovery of the data that’s been lost. A DBMS will have the
recovery manager which retrieves the data making it another advantage over file
systems.
 Data security: A file system provides a password mechanism to protect the
database but how long can the password be protected? No one can guarantee that.
This doesn’t happen in the case of DBMS. DBMS has specialized features that
help provide shielding to its data.
 Backup: It creates a backup subsystem to restore the data if required.
 Interfaces: It provides different multiple user interfaces like graphical user
interface and application program interface.
 Easy Maintenance: It is easily maintainable due to its centralized nature.
Data Abstraction
Database systems comprise complex data structures. In order to make the system efficient in
terms of retrieval of data, and reduce complexity in terms of usability of users, developers
use abstraction i.e., hide irrelevant details from the users. This approach simplifies database
design.
There are mainly 3 levels of data abstraction:
Physical: This is the lowest level of data abstraction. It tells us how the data is actually stored
in memory. The access methods like sequential or random access and file organization
methods like B+ trees and hashing are used for the same. Usability, size of memory, and the
number of times the records are factors that we need to know while designing the database.
Suppose we need to store the details of an employee. Blocks of storage and the amount of
memory used for these purposes are kept hidden from the user.

Logical: This level comprises the information that is actually stored in the database in the
form of tables. It also stores the relationship among the data entities in relatively simple
structures. At this level, the information available to the user at the view level is unknown.
We can store the various attributes of an employee and relationships, e.g. with the manager
can also be stored.

View: This is the highest level of abstraction. Only a part of the actual database is viewed
by the users. This level exists to ease the accessibility of the database by an individual user.
Users view data in the form of rows and columns. Tables and relations are used to store
data. Multiple views of the same database may exist. Users can just view the data and
interact with the database, storage and implementation details are hidden from them.

Example: In case of storing customer data,


Physical level – it will contain block of storages (bytes, GB, TB, etc)
Logical level – it will contain the fields and the attributes of data.
View level – it works with CLI or GUI access of database
The main purpose of data abstraction is to achieve data independence in order to save the
time and cost required when the database is modified or altered.

Data Independence
Data Independence is mainly defined as a property of DBMS that helps you to change the
database schema at one level of a system without requiring to change the schema at the next
level. it helps to keep the data separated from all program that makes use of it.
We have namely two levels of data independence arising from these levels of abstraction:

Physical level data independence: It refers to the characteristic of being able to modify the
physical schema without any alterations to the conceptual or logical schema, done for
optimization purposes, e.g., the Conceptual structure of the database would not be affected
by any change in storage size of the database system server. Changing from sequential to
random access files is one such example. These alterations or modifications to the physical
structure may include:

 Utilizing new storage devices.


 Modifying data structures used for storage.
 Altering indexes or using alternative file organization techniques etc.

Logical level data independence: It refers characteristic of being able to modify the logical
schema without affecting the external schema or application program. The user view of the
data would not be affected by any changes to the conceptual view of the data. These changes
may include insertion or deletion of attributes, altering table structures entities or
relationships to the logical schema, etc.

Database Languages
o A DBMS has appropriate languages and interfaces to express database queries and
updates.
o Database languages can be used to read, store and update the data in the database.

Types of Database Languages


1. Data Definition Language (DDL)

o DDL stands for Data Definition Language. It is used to define database structure or
pattern.
o It is used to create schema, tables, indexes, constraints, etc. in the database.
o Using the DDL statements, you can create the skeleton of the database.
o Data definition language is used to store the information of metadata like the number
of tables and schemas, their names, indexes, columns in each table, constraints, etc.

Here are some tasks that come under DDL:

o Create: It is used to create objects in the database.


o Alter: It is used to alter the structure of the database.
o Drop: It is used to delete objects from the database.
o Truncate: It is used to remove all records from a table.
o Rename: It is used to rename an object.
o Comment: It is used to comment on the data dictionary.

These commands are used to update the database schema that's why they come under Data
definition language.

2. Data Manipulation Language (DML)

DML stands for Data Manipulation Language. It is used for accessing and manipulating data
in a database. It handles user requests.

Here are some tasks that come under DML:

o Select: It is used to retrieve data from a database.


o Insert: It is used to insert data into a table.
o Update: It is used to update existing data within a table.
o Delete: It is used to delete all records from a table.
o Merge: It performs UPSERT operation, i.e., insert or update operations.
o Call: It is used to call a structured query language or a Java subprogram.
o Explain Plan: It has the parameter of explaining data.
o Lock Table: It controls concurrency.
3. Data Control Language (DCL)

o DCL stands for Data Control Language. It is used to retrieve the stored or saved data.
o The DCL execution is transactional. It also has rollback parameters.

(But in Oracle database, the execution of data control language does not have the feature
of rolling back.)

Here are some tasks that come under DCL:

o Grant: It is used to give user access privileges to a database.


o Revoke: It is used to take back permissions from the user.

There are the following operations which have the authorization of Revoke:

CONNECT, INSERT, USAGE, EXECUTE, DELETE, UPDATE and SELECT.

4. Transaction Control Language (TCL)

TCL is used to run the changes made by the DML statement. TCL can be grouped into a logical
transaction.

Here are some tasks that come under TCL:

o Commit: It is used to save the transaction on the database.


o Rollback: It is used to restore the database to original since the last Commit.

You might also like