Skip to main content

Generalisation and Specialisation

GENERALISATION
Consider the account entity set with attributes accno and balance. Each account can be classified as SAVINGS ACCOUNT or CURRENT ACCOUNT. Each of these is described by a set of attributes which include all the attributes of the account entity set PLUS some additional attributes , SAVINGS ACCOUNT entities are described by the attribute INTEREST RATE ,while CURRENT ACCOUNT are described by the attribute OVER DRAFT AMOUNT. There are similarities between the current account entity set and the saving account entity set in the sense that they have several attributes in common . This commonality can be expressed by generalization. Generalization is a containment relationship that exist between a higher level entity set and one or more lower level entity sets .Here the ACCOUNT is the higher level entity and SAVINGS ACCOUNT & CURRENT ACCOUNT are LOWERLEVEL ENTITY SETS. In an ER diagram generalization is represented by a triangular component labeled “ISA" it stands for "is a ". For example Savings Account "is an " account .The attributes of higher level entity sets are inherited by the lower level entity sets.




ISA realtionship between ACCOUNT - SAVINGS ACCOUNT & CURRENT ACCOUNT

There are two methods for transforming an ER diagram, which includes generalization, to a tabular form.
FIRST METHOD - Create a table for the higher level entity set. For each lower level entity set create a table which includes columns for each of the attributes of that entity set, plus columns for each of the attributes of the primary key of the higher level entity set.
Then we will have three tables for the above ER diagram .
a). Account with columns accno & balance
b). Savings account with columns accno & interest rate
c). Current account with columns accno. & overdraft amount
SECOND METHOD - Do not create a table for higher level entity set. For each lower level entity set create a table which includes columns for each of the attributes of that entity set, plus columns for each of the attributes of the higher level entity set.
Then we will have two tables for the above ER diagram .
a). Savings account with columns accno, balance & interest rate
b). Current Account with columns accno, balance & overdraft amount.

AGGREGATION
Consider a data base describing information about employees who work on a particular project and uses a number of different machines in there work ,we will obtain the following ER diagram using our basic ER model. We may think that the relation ship sets WORKS & USES can be combined into one single relationship set. But they cannot be combined. Because the ternary relationship obtained by combining these cannot represent a relationship between a manager, (who doesn’t uses any machine) and a project.
Aggregation is an abstraction through which relationships are treated as higher level entities. In this case we consider the relationship set work and the entity sets employee and project as a higher level entity set WORKS. Such an entity is treated in the same manner as any other entity set using the diagram WORKS.






Aggregation :: EMPLOYEE - PROJECT - MACHINE relationship

Using the normal transformation procedure, we will get table for employee, project, machine , works and uses. The table for relationship set uses will include columns for each attribute in the primary key of the entity set machine and the relation ship works. ie. { empcode, pcode, mcode}.

Comments

Post a Comment

Popular posts from this blog

Writing a Bash Shell Script

Bash shell scripts in Linux are text files that contain a series of commands that can be executed by the Bash shell. Bash (Bourne Again Shell) is a popular shell in Linux and UNIX systems, and shell scripts are used to automate tasks, configure systems, or perform a sequence of operations. How to Write a Bash Shell Script Create a New File: You can create a new script using any text editor like nano , vim , or gedit . gedit myscript.sh Write the Script: A basic shell script begins with a "shebang" ( #!/bin/bash ) to specify the interpreter that will be used to execute the script. The rest of the file contains the commands to be run. Example of a simple script: #!/bin/bash # This is a comment echo "Hello, World!" # Print "Hello, World!" #!/bin/bash : Specifies that the script will be executed using the Bash shell. echo "Hello, World!" : A command that prints the string "Hello, World!" to the terminal. Comments: Any line starting ...

Linux History and GNU

Linus Torvalds ,a student at the University of Helsinki started developing Linux to create a system similar to MINIX, a UNIX operating system. In 1991 he released version 0.02; Version 1.0 of the Linux kernel, the core of the operating system, was released in 1994. About the same time, American software developer Richard Stallman and the FSF made efforts to create an open-source UNIX-like operating system called GNU. In contrast to Torvalds, Stallman and the FSF started by creating utilities for the operating system first. These utilities were then added to the Linux kernel to create a complete system called GNU/Linux, or, less precisely, just Linux. Linus Torvalds Richard Stallman Linux grew throughout the 1990s because of the efforts of hobbyist developers. Although Linux is not as user-friendly as the popular Microsoft Windows and Mac OS operating systems, it is an efficient and reliable system that rarely crashes. Combined with Apache, an open-source Web server, Linux accounts fo...

Different syntax for writing arithmetic expressions in bash shell

#!/bin/bash echo "Enter two numbers" read a b s=`expr $a + $b` echo "Sum1=$s" s=$[$a+$b] echo "sum2=$s" ((s=$a+$b)) echo "sum3=$s" ((s=a+b)) echo "sum3=$s" let s=$a+$b echo "sum4=$s" let s=a+b echo "sum4=$s" Note:bash shell support only integer arithmetic.zsh support operations on real numbers.We can use bc in bash shell to do real arithmetic. Eg: echo "$a*$b"|bc # where a and b are real Mathematical Operators With Integers Operator Description Example Evaluates To + Addition echo $(( 20 + 5 )) 25 - Subtraction echo $(( 20 - 5 )) 15 / Division echo $(( 20 / 5 )) 4 * Multiplication echo $(( 20 * 5 )) 100  % Modulus echo $(( 20 % 3 )) 2 ++ post-increment (add variable value by 1) x=5 echo $(( x++ )) echo $(( x++ )) 5 6 -- post-decrement (subtract variable value by 1) x=5 echo $(( x-- )) 4 ** Exponentiation x=2 y=3 echo $(( x ** y )) 8