You are on page 1of 12

Data models in DBMS

Data Model is a logical structure of Database. It describes the design of database to reflect entities,
attributes, relationship among data, constrains etc.
Types of Data Models
There are several types of data models in DBMS. here, we will just see a basic overview of types of
models.
Object based logical Models – Describe data at the conceptual and view levels.
1. E-R Model
2. Object oriented Model
Record based logical Models – Like Object based model, they also describe data at the conceptual and
view levels. These models specify logical structure of database with records, fields and attributes.
1. Relational Model
2. Hierarchical Model
3. Network Model – Network Model is same as hierarchical model except that it has graph-like
structure rather than a tree-based structure. Unlike hierarchical model, this model allows each
record to have more than one parent record.
Physical Data Models – These models describe data at the lowest level of abstraction.
-----------------------------------------------------------------------------------------------------------------------------
Entity Relationship Diagram – ER Diagram in DBMS
An Entity–relationship model (ER model) describes the structure of a database with the help of
a diagram, which is known as Entity Relationship Diagram (ER Diagram). An ER model is a design or
blueprint of a database that can later be implemented as a database. The main components of E-R model
are: entity set and relationship set.
What is an Entity Relationship Diagram (ER Diagram)?
An ER diagram shows the relationship among entity sets. An entity set is a group of similar
entities and these entities can have attributes. In terms of DBMS, an entity is a table or attribute of a table
in database, so by showing relationship among tables and their attributes, ER diagram shows the complete
logical structure of a database. Let’s have a look at a simple ER diagram to understand this concept.
A simple ER Diagram:
In the following diagram we have two entities Student and College and their relationship.
The relationship between Student and College is many to one as a college can have many students
however a student cannot study in multiple colleges at the same time. Student entity has attributes such as
Stu_Id, Stu_Name & Stu_Addr and College entity has attributes such as Col_ID & Col_Name.
Here are the geometric shapes and their meaning in an E-R Diagram.
Rectangle: Represents Entity sets.
Ellipses: Attributes
Diamonds: Relationship Set
Lines: They link attributes to Entity Sets and Entity sets to Relationship Set
Double Ellipses: Multivalued Attributes
Dashed Ellipses: Derived Attributes
Double Rectangles: Weak Entity Sets
Double Lines: Total participation of an entity in a relationship set
Components of a ER Diagram

As shown in the above diagram, an ER diagram has three main components:


1. Entity
2. Attribute
3. Relationship
1. Entity
An entity is an object or component of data. An entity is represented as rectangle in an
ER diagram. For example: In the following ER diagram we have two entities Student and College and
these two entities have many to one relationship as many students study in a single college.

Weak Entity:
An entity that cannot be uniquely identified by its own attributes and relies on the relationship with
other entity is called weak entity. The weak entity is represented by a double rectangle. For example – a
bank account cannot be uniquely identified without knowing the bank to which the account belongs, so
bank account is a weak entity.

2. Attribute
An attribute describes the property of an entity. An attribute is represented as Oval in an ER diagram.
There are four types of attributes:
1. Key attribute
2. Composite attribute
3. Multivalued attribute
4. Derived attribute
1. Key attribute:
A key attribute can uniquely identify an entity from an entity set. For example, student roll number
can uniquely identify a student from a set of students. Key attribute is represented by oval same as other
attributes however the text of key attribute is underlined.
2. Composite attribute:
An attribute that is a combination of other attributes is known as composite attribute. For example,
In student entity, the student address is a composite attribute as an address is composed of other attributes
such as pin code, state, country.

3. Multivalued attribute:
An attribute that can hold multiple values is known as multivalued attribute. It is represented
with double ovals in an ER Diagram. For example – A person can have more than one phone numbers so
the phone number attribute is multivalued.
4. Derived attribute:
A derived attribute is one whose value is dynamic and derived from another attribute. It is represented
by dashed oval in an ER Diagram. For example – Person age is a derived attribute as it changes over time
and can be derived from another attribute (Date of birth).
E-R diagram with multivalued and derived attributes:

3. Relationship
A relationship is represented by diamond shape in ER diagram, it shows the relationship among entities.
There are four types of relationships:
1. One to One
2. One to Many
3. Many to One
4. Many to Many
1. One to One Relationship
When a single instance of an entity is associated with a single instance of another entity then it is called
one to one relationship. For example, a person has only one passport and a passport is given to one person.

2. One to Many Relationship


When a single instance of an entity is associated with more than one instances of another entity then it is
called one to many relationship. For example – a customer can place many orders but a order cannot be
placed by many customers.

3. Many to One Relationship


When more than one instances of an entity is associated with a single instance of another entity then it is
called many to one relationship. For example – many students can study in a single college but a student
cannot study in many colleges at the same time.
4. Many to Many Relationship
When more than one instances of an entity is associated with more than one instances of another entity
then it is called many to many relationship. For example, a can be assigned to many projects and a project
can be assigned to many students.

Total Participation of an Entity set


A Total participation of an entity set represents that each entity in entity set must have at least one
relationship in a relationship set. For example: In the below diagram each college must have at-least one
associated Student.
DBMS Generalization
Generalization is a process in which the common attributes of more than one entities form a new entity.
This newly formed entity is called generalized entity.
Generalization Example
Let’s say we have two entities Student and Teacher.
Attributes of Entity Student are: Name, Address & Grade
Attributes of Entity Teacher are: Name, Address & Salary
The ER diagram before generalization looks like this:
These two entities have two common attributes: Name and Address, we can make a generalized entity with
these common attributes. Let’s have a look at the ER model after generalization.
The ER diagram after generalization:
We have created a new generalized entity Person and this entity has the common attributes of both the
entities. As you can see in the following ER diagram that after the generalization process the entities
Student and Teacher only has the specialized attributes Grade and Salary respectively and their common
attributes (Name & Address) are now associated with a new entity Person which is in the relationship with
both the entities (Student & Teacher).

Note:
1. Generalization uses bottom-up approach where two or more lower level entities combine together to
form a higher level new entity.
2. The new generalized entity can further combine together with lower level entity to create a further
higher level generalized entity.
DBMS Specialization
Specialization is a process in which an entity is divided into sub-entities. You can think of it as a reverse
process of generalization, in generalization two entities combine together to form a new higher level entity.
Specialization is a top-down process.
The idea behind Specialization is to find the subsets of entities that have few distinguish attributes. For
example – Consider an entity employee which can be further classified as sub-entities Technician,
Engineer & Accountant because these sub entities have some distinguish attributes.
Specialization Example

In the above diagram, we can see that we have a higher level entity “Employee” which we have divided in
sub entities “Technician”, “Engineer” & “Accountant”. All of these are just an employee of a company,
however their role is completely different and they have few different attributes. Just for the example, I
have shown that Technician handles service requests, Engineer works on a project and Accountant handles
the credit & debit details. All of these three employee types have few attributes common such as name &
salary which we had left associated with the parent entity “Employee” as shown in the above diagram.
DBMS Aggregration
Aggregation is a process in which a single entity alone is not able to make sense in a relationship so the
relationship of two entities acts as one entity. I know it sounds confusing but don’t worry the example we
will take, will clear all the doubts.

Aggregration Example
In real world, we know that a manager not only manages the employee working under them but he has to
manage the project as well. In such scenario if entity “Manager” makes a “manages” relationship with
either “Employee” or “Project” entity alone then it will not make any sense because he has to manage both.
In these cases the relationship of two entities acts as one entity. In our example, the relationship “Works-
On” between “Employee” & “Project” acts as one entity that has a relationship “Manages” with the entity
“Manager”.
Relational model in DBMS
In relational model, the data and relationships are represented by collection of inter-related tables. Each
table is a group of column and rows, where column represents attribute of an entity and rows represents
records.
Sample relationship Model: Student table with 3 columns and four records.
Table: Student

Stu_Id Stu_Name Stu_Age

111 Ashish 23

123 Saurav 22

169 Lester 24

234 Lou 26

Table: Course
Stu_Id Course_Id Course_Name

111 C01 Science

111 C02 DBMS

169 C22 Java

Computer
169 C39
Networks
Here Stu_Id, Stu_Name & Stu_Age are attributes of table Student and Stu_Id, Course_Id & Course_Name
are attributes of table Course. The rows with values are the records (commonly known as tuples).
Cardinality in DBMS
In DBMS you may hear cardinality term at two different places and it has two different meanings as well.
In Context of Data Models:
In terms of data models, cardinality refers to the relationship between two tables. Relationship can be of
four types as we have already seen in Entity relationship guide:
One to One – A single row of first table associates with single row of second table. For example, a
relationship between person and passport table is one to one because a person can have only one passport
and a passport can be assigned to only one person.
One to Many – A single row of first table associates with more than one rows of second table. For
example, relationship between customer and order table is one to many because a customer can place many
orders but a order can be placed by a single customer alone.
Many to One – Many rows of first table associate with a single row of second table. For example,
relationship between student and university is many to one because a university can have many students
but a student can only study only in single university at a time.
Many to Many – Many rows of first table associate with many rows of second table. For example,
relationship between student and course table is many to many because a student can take many courses at
a time and a course can be assigned to many students.
In Context of Query Optimization:
In terms of query, the cardinality refers to the uniqueness of a column in a table. The column with all
unique values would be having the high cardinality and the column with all duplicate values would be
having the low cardinality. These cardinality scores helps in query optimization.

SQL – CREATE DATABASE Statement

We will learn how to create a database. The ideal way to store the data is to first create a database and then
create tables into it.
CREATE DATABASE Statement
Syntax:
We use CREATE DATABASE statement in order to create a database. This is how it is used:
CREATE DATABASE DBName;
Here DBName can be any string that would represent the database name.
Example – The below statement would create a database named employee
SQL> CREATE DATABASE Employee;
In order to get the list of all the databases, you can use SHOW DATABASES statement.
Example –
SQL> SHOW DATABASES;
+--------------------+
| Database |
+--------------------+
| BeginnersBook |
| AbcTemp |
| Employee |
| Customers |
| Student |
| Faculty |
| MyTest |
| Demo |
+--------------------+
8 rows in set (0.00 sec)
As you can see this statement listed all the databases. You can also find the “Employee” database in the
above list that we have created above using the CREATE DATABASE statement.

You might also like