CSE Student Course Guide
CSE Student Course Guide
CSE
                                                                          Home Mech
                                                                           e
                                                                    EEE
                                                                                 ECE
                                      Physics
                                    Basic     for Engineering
                                          Electrical and                   Data Structure
  Problem Solving and                 Science Engineering
                                  Electronics
  Python Programming                                                      Object Oriented
                                    Programming in C
                                                                           Programming
Elective-Management
Professional Elective II
  Professional Elective IV
                                               www.Poriyaan.in
         UNIT I                                 RELATIONAL DATABASES
         Purpose of Database System – Views of data – Data Models – Database System Architecture – Introduction to
         relational databases – Relational Model – Keys – Relational Algebra – SQL fundamentals – Advanced SQL
         features – Embedded SQL– Dynamic SQL
         INTRODUCTION
         DATABASE
         Database is collection of data which is related by some aspect. Data is collection of facts and figures which can be
         processed to produce information. Mostly data represents recordable facts. Data aids in producing information which
         is based on facts. A database management system stores data, in such a way which is easier to retrieve, manipulate
         and helps to produce information.
         So a database is a collection of related data that we can use for
          Defining - specifying types of data
          Constructing - storing & populating
          Manipulating - querying, updating, reporting
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                               1
                                                www.Poriyaan.in
         2. Difficulty in accessing data
         File processing environments do not allow needed data to be retrieved in a convenient and efficient manner.
         3.Data isolation
         Because data are scattered in various files, and files may be in different formats, writing new application
         programs to retrieve the appropriate data is difficult.
         4.Integrity problems
         The data values stored in the database must satisfy certain types of consistency constraints. Example:
         The balance of certain types of bank accounts may never fall below a prescribed amount . Developers enforce
         these constraints in the system by addition appropriate code in the various application programs
         5.Atomicity problems
         Atomic means the transaction must happen in its entirety or not at all. It is difficult to ensure atomicity in a
         conventional file processing system.
         Example:
         Consider a program to transfer $50 from account A to account B. If a system failure occurs during the execution of
         the program, it is possible that the $50 was removed from account A but was not credited to account B, resulting in
         an inconsistent database state.
         6.Concurrent access anomalies
         For the sake of overall performance of the system and faster response, many systems allow multiple users to update
         the data simultaneously. In such an environment, interaction of concurrent updates is possible and may result in
         inconsistent data. To guard against this possibility, the system must maintain some form of supervision. But
         supervision is difficult to
         provide because data may be accessed by many different application programs that have not been coordinated
         previously.
         Example: When several reservation clerks try to assign a seat on an airline flight, the system should ensure
         that each seat can be accessed by only one clerk at a time for assignment to a passenger.
         7. Security problems
         Enforcing security constraints to the file processing system is difficult.
         APPLICATION OF DATABASE
         Database 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
               Telecommunication: Call History, Billing
               Credit card transactions: Purchase details,Statements
         VIEWS OF DATA
         It refers that how database is actually stored in database, what data and structure of data used by database for data.
         So describe all this database provides user with views and these are
              Data abstraction
              Instances and schemas
           Dataabstraction
           As a data in database are stored with very complex data structure so when user come and want to access any data,
           he will not be able to access data if he has go through this data structure. So to simplify the interaction of user
           and database, DBMS hides some information which is not of user interest, a this is called data abstraction:- So
           developer hides complexity from user and store abstract view of data.
           Data abstraction has three level of abstractions
              level / internal level
              Logical level / conceptual level
              view level / external level
           Physical level:- this is the lowest level of data abstraction which describe How data is actual stored in database.
           This level basically describe the data structure and access path /indexing use for accessing file.
           Logical level:- The next level of abstraction describe what data are stored in the database and what are the
           relationship existed among those of data.
           View level:- In this level user only interact with database and the complexity remain unview . user see data and
           there may be many views of one data like chart and graph.
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                               2
                                               www.Poriyaan.in
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                                3
                                               www.Poriyaan.in
           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.
         Three Schema Architecture
         The goal of the three schema architecture is to separate the user applications and the physical database. The schemas
         can be defined at the following levels:
             1. The internal level – has an internal schema which describes the physical storage structure of the database.
                 Uses a physical data model and describes the complete details of data storage and access paths for the
                 database.
            2. The conceptual level – has a conceptual schema which describes the structure of the database for users. It
               hides the details of the physical storage structures, and concentrates on describing entities, data types,
               relationships, user operations and constraints. Usually a representational data model is used to describe the
               conceptual schema.
            3. The External or View level – includes external schemas or user vies. Each external schema describes the
               part of the database that a particular user group is interested in and hides the rest of the database from that
               user group. Represented using the representational data model.
         The three schema architecture is used to visualize the schema levels in a database. The three schemas are only
         descriptions of data, the data only actually exists is at the physical level.
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                              4
                                               www.Poriyaan.in
         COMPONENTS OF DBMS
         Database Users
         Users are differentiated by the way they expect to interact with the system
                              • Application programmers
                              • Sophisticated users
                              • Naïve users
                              • Database Administrator
                              • Specialized users etc,.
         Application programmers:
                      Professionals who write application programs and using these application programs they interact with
         the database system
         Sophisticated users :
                       These user interact with the database system without writing programs, But they submit queries to
         retrieve the information
         Specialized users:
                          Who write specialized database applications to interact with the database system.
         Naïve users:
                         Interacts with the database system by invoking some application programs that have been written
         previously by application programmers
          Eg : people accessing database over the web
         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.
                        Schema definition
                        Access method definition
                        Schema and physical organization modification
                        Granting user authority to access the database
                        Monitoring performance
         Storage Manager
          The Storage Manager include these following components/modules
                        Authorization Manager
                        Transaction Manager
                        File Manager
                        Buffer Manager
               Storage manager is a program module that provides the interface between the low-level data stored in the
                  database and the application programs and queries submitted to the system.
               The storage manager is responsible to the following tasks:
                            interaction with the file manager
                            efficient storing, retrieving and updating of data
                                            Authorization Manager
                                                 Checks whether the user is an authorized person or not
                                                 Test the satisfaction of integrity constraints
                                            Transaction Manager
                  Responsible for concurrent transaction execution It ensures that the database remains in a consistent state
                  despite of the system failure
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                               5
                                                www.Poriyaan.in
         EVOLUTION OF RDBMS
         Before the acceptance of Codd’s Relational Model, database management systems was just an ad hoc collection of
         data designed to solve a particular type of problem, later extended to solve more basic purposes. This led to complex
         systems, which were difficult to understand, install, maintain and use. These database systems were plagued with the
         following problems:
              • They required large budgets and staffs of people with special skills that were in short supply.
              • Database administrators’ staff and application developers required prior preparation to access these database
                 systems.
              • End-user access to the data was rarely provided.
              • These database systems did not support the implementation of business logic as a DBMS responsibility.
         Hence, the objective of developing a relational model was to address each and every one of the shortcomings that
         plagued those systems that existed at the end of the 1960s decade, and make DBMS products more widely appealing
         to all kinds of users.
         The existing relational database management systems offer powerful, yet simple solutions for a wide variety of
         commercial and scientific application problems. Almost every industry uses relational systems to store, update and
         retrieve data for operational, transaction, as well as decision support systems.
          RELATIONAL DATABASE
         A relational database is a database system in which the database is organized and accessed according to the
         relationships between data items without the need for any consideration of physical orientation and relationship.
         Relationships between data items are expressed by means of tables.
         It is a tool, which can help you store, manage and disseminate information of various kinds. It is a collection of
         objects, tables, queries, forms, reports, and macros, all stored in a computer program all of which are inter-related.
         It is a method of structuring data in the form of records, so that relations between different entities and attributes can
         be used for data access and transformation.
         RELATIONAL DATABASE MANAGEMENT SYSTEM
         A Relational Database Management System (RDBMS) is a system, which allows us to perceive data as tables (and
         nothing but tables), and operators necessary to manipulate that data are at the user’s disposal.
         Features of an RDBMS
         The features of a relational database are as follows:
               The ability to create multiple relations (tables) and enter data into them
               An interactive query language
               Retrieval of information stored in more than one table
               Provides a Catalog or Dictionary, which itself consists of tables ( called system tables )
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                                   6
                                                 www.Poriyaan.in
                   stored. It is also called a relation or an entity.
             •     Row: Rows represent collection of data required for a particular entity. In order to identify each row as
                   unique there should be a unique identifier called the primary key, which allows no duplicate rows. For
                   example in a library every member is unique and hence is given a membership number, which uniquely
                   identifies each member. A row is also called a record or a tuple.
               • Column: Columns represent characteristics or attributes of an entity. Each attribute maps onto a column of a
                   table. Hence, a column is also known as an attribute.
               • Relationship: Relationships represent a logical link between two tables. A relationship is depicted by a
                   foreign key column.
               • Degree: number of attributes
               • Cardinality: number of tuples
               • An attribute of an entity has a particular value. The set of possible values That a given attribute can
                   have is called its domain.
         KEYS AND THEIR USE
         Key: An attribute or set of attributes whose values uniquely identify each entity in an entity set is called a key for
         that entity set.
         Super Key: If we add additional attributes to a key, the resulting combination would still uniquely identify an
         instance of the entity set. Such augmented keys are called super keys.
         Primary Key: It is a minimum super key.
         It is a unique identifier for the table (a column or a column combination with the property that at any given time no
         two rows of the table contain the same value in that column or column combination).
         Foreign Key: A foreign key is a field (or collection of fields) in one table that uniquely identifies a row of another
         table. In simpler words, the foreign key is defined in a second table, but it refers to the primary key in the first table.
         Candidate Key: There may be two or more attributes or combinations of attributes that uniquely identify an
         instance of an entity set. These attributes or combinations of attributes are called candidate keys.
         Secondary Key: A secondary key is an attribute or combination of attributes that may not be a candidate key, but
         that classifies the entity set on a particular characteristic. Any key consisting of a single attribute is called a simple
         key, while that consisting of a combination of attributes is called a composite key.
         Referential Integrity
         Referential Integrity can be defined as an integrity constraint that specifies that the value (or existence) of an
         attribute in one relation depend on the value (or existence) of an attribute in the same or another relation. Referential
         integrity in a relational database is consistency between coupled tables. It is usually enforced by the combination of
         a primary key and a foreign key. For referential integrity to hold, any field in a table that is declared a foreign key
         can contain only values from a parent table's primary key field. For instance, deleting a record that contains a value
         referred to by a foreign key in another table would break referential integrity.
                   Relational Model
          Relational data model is the primary data model, which is used widely around the world for data storage and
          processing. This model is simple and it has all the properties and capabilities required to process data with storage
          efficiency.
         Concepts
          Tables − In relational data model, relations are saved in the format of Tables. This format stores the relation among
          entities. A table has rows and columns, where rows represents records and columns represent the attributes.
          Tuple − A single row of a table, which contains a single record for that relation is called a tuple.
          Relation instance − A finite set of tuples in the relational database system represents relation instance. Relation
          instances do not have duplicate tuples.
          Relation schema − A relation schema describes the relation name (table name), attributes, and their names.
          Relation key − Each row has one or more attributes, known as relation key, which can identify the row in the
          relation (table) uniquely.
          Attribute domain − Every attribute has some pre-defined value scope, known as attribute domain.
         Constraints
          Every relation has some conditions that must hold for it to be a valid relation. These conditions are
          called Relational Integrity Constraints. There are three main integrity constraints −
                Key constraints
                Domain constraints
                Referential integrity constraints
         Key Constraints
          There must be at least one minimal subset of attributes in the relation, which can identify a tuple uniquely. This
          minimal subset of attributes is called keyfor that relation. If there are more than one such minimal subsets, these are
          called candidate keys.
          Key constraints force that −
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                                    7
                                                              www.Poriyaan.in
                 in a relation with a key attribute, no two tuples can have identical values for key attributes.
                 a key attribute can not have NULL values.
          Key constraints are also referred to as Entity Constraints.
         Domain Constraints
          Attributes have specific values in real-world scenario. For example, age can only be a positive integer. The same
         constraints have been tried to employ on the attributes of a relation. Every attribute is bound to have a specific
         range of values. For example, age cannot be less than zero and telephone numbers cannot contain a digit outside 0-
         Referential integrity Constraints
          Referential integrity constraints work on the concept of Foreign Keys. A foreign key is a key attribute of a relation
          that can be referred in other relation.
          Referential integrity constraint states that if a relation refers to a key attribute of a different or same relation, then
          that key element must exist.
          Relational database systems are expected to be equipped with a query language that can assist its users to query the
          database instances. There are two kinds of query languages − relational algebra and relational calculus.
         Relational Algebra
         Relational algebra is a procedural query language, which takes instances of relations as input and yields instances
         of relations as output. It uses operators to perform queries. An operator can be either unary or binary. They accept
         relations as their input and yield relations as their output. Relational algebra is performed recursively on a relation
         and intermediate results are also considered relations.
         The fundamental operations of relational algebra are as follows −
              Select
              Project
              Union
              Set different
              Cartesian product
              Rename
         We will discuss all these operations in the following sections.
         Select Operation(σ)
         It selects tuples that satisfy the given predicate from a relation.
         Notation − σp(r)
         Where σ stands for selection predicate and r stands for relation. p is prepositional logic formula which may use
         connectors like and, or, and not. These terms may use relational operators like − =, ≠, ≥, < , >, ≤.
         For example −
         σsubject = "database"(Books)
         Output − Selects tuples from books where subject is 'database'.
         σsubject = "database" and price = "450"(Books)
          Output − Selects tuples from books where subject is 'database' and 'price' is 450.
         σsubject = "database" and price = "450" or year > "2010"(Books)
         Output − Selects tuples from books where subject is 'database' and 'price' is 450 or those books published after
         2010.
         Project Operation(∏)
         It projects column(s) that satisfy a given predicate.
         Notation − ∏A1, A2, An (r)
         Where A1, A2 , An are attribute names of relation r.
         Duplicate rows are automatically eliminated, as relation is a set.
         For example −
         ∏subject, author (Books)
         Selects and projects columns named as subject and author from the relation Books.
         Union Operation(∪)
         It performs binary union between two given relations and is defined as −
         r ∪ s = { t | t ∈ r or t ∈ s}
          Notation − r U s
          Where r and s are either database relations or relation result set (temporary relation).
          For a union operation to be valid, the following conditions must hold −
              r, and s must have the same number of attributes.
              Attribute domains must be compatible.
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                                    8
                                                        www.Poriyaan.in
                  Duplicate tuples are automatically eliminated.
         ∏ author (Books) ∪ ∏ author (Articles)
         Output − Projects the names of the authors who have either written a book or an article or both.
         Set Difference (−)
         The result of set difference operation is tuples, which are present in one relation but are not in the second relation.
         Notation − r − s
         Finds all the tuples that are present in r but not in s.
         ∏ author (Books) − ∏ author (Articles)
         Output − Provides the name of authors who have written books but not articles.
         Cartesian Product(Χ)
         Combines information of two different relations into one.
         Notation − r Χ s
         Where r and s are relations and their output will be defined as −
         r Χ s = { q t | q ∈ r and t ∈ s}
         σauthor = 'tutorialspoint'(Books Χ Articles)
         Output − Yields a relation, which shows all the books and articles written by tutorialspoint.
         Rename Operation(ρ)
         The results of relational algebra are also relations but without any name. The rename operation allows us to rename
         the output relation. 'rename' operation is denoted with small Greek letter rho ρ.
         Notation − ρ x (E)
         Where the result of expression E is saved with name of x.
         Additional operations are −
              Set intersection
              Assignment
              Natural join
                 SQL FUNDAMENTALS:
         SQL is a standard computer language for accessing and manipulating databases.
         What is SQL?
            SQL stands for Structured Query Language
            SQL allows you to access a database
            SQL is an ANSI standard computer language
            SQL can execute queries against a database
            SQL can retrieve data from a database
            SQL can insert new records in a database
            SQL can delete records from a database
            SQL can update records in a database
            SQL is easy to learn
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                                9
                                                www.Poriyaan.in
         SQL Queries
         With SQL, we can query a database and have a result set returned.
         A query like this:
         SELECT LastName FROM Persons
         Gives a result set like this:
         LastName
         Hansen
         Svendson
         Pettersen
         Note: Some database systems require a semicolon at the end of the SQL statement. We don't use the semicolon in
         our tutorials.
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                             10
                                               www.Poriyaan.in
         SELECT * FROM Persons
         Result
         LastName              FirstName                         Address                            City
         Hansen                Ola                               Timoteivn 10                       Sandnes
         Svendson              Tove                              Borgvn 23                          Sandnes
         Pettersen             Kari                              Storgt 20                          Stavanger
         "Orders" table
         Company                 OrderNumber
         Sega                    3412
         W3Schools               2312
         Trio                    4678
         W3Schools               6798
         Result
         Company
         Sega
         W3Schools
         Trio
         W3Schools
         Note that "W3Schools" is listed twice in the result-set.
         To select only DIFFERENT values from the column named "Company" we use a SELECT DISTINCT statement
         like this:
         SELECT DISTINCT Company FROM Orders
         Result:
         Company
         Sega
         W3Schools
         Trio
         Now "W3Schools" is listed only once in the result-set.
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                             11
                                               www.Poriyaan.in
         The WHERE clause is used to specify a selection criterion.
         Using Quotes
         Note that we have used single quotes around the conditional values in the examples.
         SQL uses single quotes around text values (most database systems will also accept double quotes). Numeric values
         should not be enclosed in quotes.
         For text values:
         This is correct:
         SELECT * FROM Persons WHERE FirstName='Tove'
         This is wrong:
         SELECT * FROM Persons WHERE FirstName=Tove
         For numeric values:
         This is correct:
         SELECT * FROM Persons WHERE Year>1965
         This is wrong:
         SELECT * FROM Persons WHERE Year>'1965'
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                         12
                                                www.Poriyaan.in
         SELECT column FROM table
         WHERE column LIKE pattern
         A "%" sign can be used to define wildcards (missing letters in the pattern) both before and after the pattern.
         Using LIKE
         The following SQL statement will return persons with first names that start with an 'O':
         SELECT * FROM Persons
         WHERE FirstName LIKE 'O%'
         The following SQL statement will return persons with first names that end with an 'a':
         SELECT * FROM Persons
         WHERE FirstName LIKE '%a'
         The following SQL statement will return persons with first names that contain the pattern 'la':
         SELECT * FROM Persons
         WHERE FirstName LIKE '%la%'
         The INSERT INTO Statement
         The INSERT INTO statement is used to insert new rows into a table.
         Syntax
         INSERT INTO table_name
         VALUES (value1, value2,... )
         You can also specify the columns for which you want to insert data:
         INSERT INTO table_name (column1, column2,. )
         VALUES (value1, value2,... )
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                       13
                                                 www.Poriyaan.in
         UPDATE table_name
         SET column_name = new_value
         WHERE column_name = some_value
         Person:
         LastName                 FirstName                              Address                        City
         Nilsen                   Fred                                   Kirkegt 56                     Stavanger
         Rasmussen                                                       Storgt 67
         Person:
         LastName                         FirstName                       Address                        City
         Nilsen                           Fred                            Kirkegt 56                     Stavanger
         Rasmussen                        Nina                            Stien 12                       Stavanger
         Delete
         Drop
         Delete a Row
         "Nina Rasmussen" is going to be deleted:
         DELETE FROM Person WHERE LastName = 'Rasmussen'
         Result
         LastName                    FirstName          Address                                         City
         Nilsen                      Fred               Kirkegt 56                                      Stavanger
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                                  14
                                             www.Poriyaan.in
         Sort the Rows
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                  15
                                                www.Poriyaan.in
         VARP(column)
         Aggregate functions in SQL Server
         Function                                 Description
         AVG(column)                              Returns the average value of a column
         BINARY_CHECKSUM
         CHECKSUM
         CHECKSUM_AGG
         COUNT(column)                            Returns the number of rows (without a NULL value) of a column
         COUNT(*)                                 Returns the number of selected rows
         COUNT(DISTINCT column)                   Returns the number of distinct results
         FIRST(column)                            Returns the value of the first record in a specified field (not supported in
                                                  SQLServer2K)
         LAST(column)                             Returns the value of the last record in a specified field (not supported in
                                                  SQLServer2K)
         MAX(column)                              Returns the highest value of a column
         MIN(column)                              Returns the lowest value of a column
         STDEV(column)
         STDEVP(column)
         SUM(column)                              Returns the total sum of a column
         VAR(column)
         VARP(column)
         Scalar functions
         Scalar functions operate against a single value, and return a single value based on the input value.
         Useful Scalar Functions in MS Access
         Function                                   Description
         UCASE(c)                                   Converts a field to upper case
          LCASE(c)                                 Converts a field to lower case
          MID(c,start[,end])                       Extract characters from a text field
          LEN(c)                                   Returns the length of a text field
          INSTR(c,char)                            Returns the numeric position of a named character within a text field
          LEFT(c,number_of_char)                   Return the left part of a text field requested
          RIGHT(c,number_of_char)                  Return the right part of a text field requested
          ROUND(c,decimals)                        Rounds a numeric field to the number of decimals specified
          MOD(x,y)                                 Returns the remainder of a division operation
         Aggregate functions (like SUM) often need an added GROUP BY functionality.
         GROUP BY
         GROUP BY... was added to SQL because aggregate functions (like SUM) return the aggregate of all column values
         every time they are called, and without the GROUP BY function it was impossible to find the sum for each
         individual group of column values.
         The syntax for the GROUP BY function is:
         SELECT column,SUM(column) FROM table GROUP BY column
         GROUP BY Example
         This "Sales" Table:
         Company                                                             Amount
         W3Schools                                                           5500
         IBM                                                                 4500
         W3Schools                                                           7100
         And This SQL:
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                              16
                                               www.Poriyaan.in
         SELECT Company, SUM(Amount) FROM Sales
         Returns this result:
          Company                                         SUM(Amount)
          W3Schools                                       17100
          IBM                                             17100
          W3Schools                                       17100
         The above code is invalid because the column returned is not part of an aggregate. A GROUP BY clause will solve
         this problem:
          SELECT Company,SUM(Amount) FROM Sales
          GROUP BY Company
         HAVING…
         HAVING ... was added to SQL because the WHERE keyword could not be used against aggregate functions (like
         SUM), and without HAVING ... it would be impossible to test for result conditions.
         The syntax for the HAVING function is:
          SELECT column,SUM(column) FROM table
          GROUP BY column
          HAVING SUM(column) condition value
         This "Sales" Table:
          Company                                                          Amount
          W3Schools                                                        5500
          IBM                                                              4500
          W3Schools                                                        7100
         This SQL:
         SELECT Company,SUM(Amount) FROM Sales
         GROUP BY Company
         HAVING SUM(Amount)>10000
         Returns this result
          Company                                         SUM(Amount)
          W3Schools                                       12600
         EMBEDDED SQL
         Embedded SQL is a method of inserting inline SQL statements or queries into the code of a programming language,
         which is known as a host language. Because the host language cannot parse SQL, the inserted SQL is parsed by an
         embedded SQL preprocessor.
         Embedded SQL is a robust and convenient method of combining the computing power of a programming language
         with SQL's specialized data management and manipulation capabilities.
         Structure of embedded SQL
         Structure of embedded SQL defines step by step process of establishing a connection with DB and executing the
         code in the DB within the high level language.
         Connection to DB
         This is the first step while writing a query in high level languages. First connection to the DB that we are accessing
         needs to be established. This can be done using the keyword CONNECT. But it has to precede with ‘EXEC SQL’ to
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                               17
                                              www.Poriyaan.in
         indicate that it is a SQL statement.
         EXEC SQL CONNECT db_name;
         EXEC SQL CONNECT HR_USER; //connects to DB HR_USER
         Once connection is established with DB, we can perform DB transactions. Since these DB transactions are
         dependent on the values and variables of the host language. Depending on their values, query will be written and
         executed. Similarly, results of DB query will be returned to the host language which will be captured by the
         variables of host language. Hence we need to declare the variables to pass the value to the query and get the values
         from query. There are two types of variables used in the host language.
                 Host variable : These are the variables of host language used to pass the value to the query as well as to
                    capture the values returned by the query. Since SQL is dependent on host language we have to use
                    variables of host language and such variables are known as host variable. But these host variables should
                    be declared within the SQL area or within SQL code. That means compiler should be able to differentiate
                    it from normal C variables. Hence we have to declare host variables within BEGIN DECLARE and END
                    DECLARE section. Again, these declare block should be enclosed within EXEC SQL and ‘;’.
         EXEC SQL BEGIN DECLARE SECTION;
              int STD_ID;
              char STD_NAME [15];
              char ADDRESS[20];
         EXEC SQL END DECLARE SECTION;
         We can note here that variables are written inside begin and end block of the SQL, but they are declared using C
         code. It does not use SQL code to declare the variables. Why? This is because they are host variables – variables of
         C language. Hence we cannot use SQL syntax to declare them. Host language supports almost all the datatypes from
         int, char, long, float, double, pointer, array, string, structures etc.
         When host variables are used in a SQL query, it should be preceded by colon – ‘:’ to indicate that it is a host
         variable. Hence when pre-compiler compiles SQL code, it substitutes the value of host variable and compiles.
         EXEC SQL SELECT * FROM STUDENT WHERE STUDENT_ID =:STD_ID;
         The following code is a simple embedded SQL program, written in C. The program illustrates many, but
         not all, of the embedded SQL techniques. The program prompts the user for an order number, retrieves the
         customer number, salesperson, and status of the order, and displays the retrieved information on the screen.
                 int main() {
                   EXEC SQL INCLUDE SQLCA;
                   EXEC SQL BEGIN DECLARE SECTION;
                     int OrderID;     /* Employee ID (from user)       */
                     int CustID;       /* Retrieved customer ID     */
                     char SalesPerson[10] /* Retrieved salesperson name      */
                     char Status[6]     /* Retrieved order status   */
                   EXEC SQL END DECLARE SECTION;
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                         18
                                                www.Poriyaan.in
                 query_error:
                   printf ("SQL error: %ld\n", sqlca->sqlcode);
                   exit();
                  bad_number:
                    printf ("Invalid order number.\n");
                    exit();
                  }
         DYNAMIC SQL
               The main disadvantage of embedded SQL is that it supports only static SQLs. If we need to build up queries at
         run time, then we can use dynamic sql. That means if query changes according to user input, then it always better to
         use dynamic SQL. Like we said above, the query when user enters student name alone and when user enters both
         student name and address, is different. If we use embedded SQL, one cannot implement this requirement in the code.
         In such case dynamic SQL helps the user to develop query depending on the values entered by him, without making
         him know which query is being executed. It can also be used when we do not know which SQL statements like
         Insert, Delete update or select needs to be used, when number of host variables is unknown, or when datatypes of
         host variables are unknown or when there is direct reference to DB objects like tables, views, indexes are required.
         However this will make user requirement simple and easy but it may make query lengthier and complex. That
         means depending upon user inputs, the query may grow or shrink making the code flexible enough to handle all the
         possibilities. In embedded SQL, compiler knows the query in advance and pre-compiler compiles the SQL code
         much before C compiles the code for execution. Hence embedded SQLs will be faster in execution. But in the case
         of dynamic SQL, queries are created, compiled and executed only at the run time. This makes the dynamic SQL
         little complex, and time consuming.
         Since query needs to be prepared at run time, in addition to the structures discussed in embedded SQL, we have
         three more clauses in dynamic SQL. These are mainly used to build the query and execute them at run time.
         PREPARE
         Since dynamic SQL builds a query at run time, as a first step we need to capture all the inputs from the user. It will
         be stored in a string variable. Depending on the inputs received from the user, string variable is appended with inputs
         and SQL keywords. These SQL like string statements are then converted into SQL query. This is done by using
         PREPARE statement.
         For example, below is the small snippet from dynamic SQL. Here sql_stmt is a character variable, which holds
         inputs from the users along with SQL commands. But is cannot be considered as SQL query as it is still a sting
         value. It needs to be converted into a proper SQL query which is done at the last line using PREPARE statement.
         Here sql_query is also a string variable, but it holds the string as a SQL query.
         EXECUTE
         This statement is used to compile and execute the SQL statements prepared in DB.
         EXEC SQL EXECUTE sql_query;
         EXECUTE IMMEDIATE
         This statement is used to prepare SQL statement as well as execute the SQL statements in DB. It performs the task
         of PREPARE and EXECUTE in a single line.
         EXEC SQL EXECUTE IMMEDIATE :sql_stmt;
         Dynamic SQL will not have any SELECT queries and host variables. But it can be any other SQL statements like
         insert, delete, update, grant etc. But when we use insert/ delete/ updates in this type, we cannot use host variables.
         All the input values will be hardcoded. Hence the SQL statements can be directly executed using EXECUTE
         IMMEDIATE rather than using PREPARE and then EXECUTE.
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                            19
                                        www.Poriyaan.in
         EXEC SQL EXECUTE IMMEDIATE ‘GRANT SELECT ON STUDENT TO Faculty’;
         EXEC SQL EXECUTE IMMEDIATE ‘DELETE FROM STUDENT WHERE STD_ID = 100’;
         EXEC SQL EXECUTE IMMEDIATE ‘UPDATE STUDENT SET ADDRESS = ‘Troy’ WHERE STD_ID =100’;
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                            20
                                                  www.Poriyaan.in
ER Model: Relationships
        When an Entity is related to another Entity, they are said to have a relationship. For example, A ClassEntity is
        related to Student entity, because students study in classes, hence this is a relationship.
        Depending upon the number of entities involved, a degree is assigned to relationships.
        For example, if 2 entities are involved, it is said to be Binary relationship, if 3 entities are involved, it is said to
        be Ternary relationship, and so on.
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                                21
                                                  www.Poriyaan.in
        Weak Entity
        A weak Entity is represented using double rectangular boxes. It is generally connected to another entity.
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                                  22
                                                 www.Poriyaan.in
        ER Diagram: Entity
        An Entity can be any object, place, person or class. In ER Diagram, an entity is represented using rectangles.
        Consider an example of an Organisation- Employee, Manager, Department, Product and many more can be taken
        as entities in an Organisation.
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                              23
                                                 www.Poriyaan.in
        The above example describes that one student can enroll only for one course and a course will also have only one
        Student. This is not what you will usually see in real-world relationships.
        One to Many Relationship
        The below example showcases this relationship, which means that 1 student can opt for many courses, but a course
        can only have 1 student. Sounds weird! This is how it is.
        The above diagram represents that one student can enroll for more than one courses. And a course can have more
        than 1 student enrolled in it.
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                             24
                                                www.Poriyaan.in
        For example, in the diagram above, we have three related entities, Company, Product and Sector. To understand the
        relationship better or to define rules around the model, we should relate two entities and then derive the third one.
        A Company produces many Products/ each product is produced by exactly one company.
        A Company operates in only one Sector / each sector has many companies operating in it.
        Considering the above two rules or relationships, we see that although the complete relationship involves three
        entities, but we are looking at two entities at a time.
        The Enhanced ER Model
        As the complexity of data increased in the late 1980s, it became more and more difficult to use the traditional ER
        Model for database modelling. Hence some improvements or enhancements were made to the existing ER Model to
        make it able to handle the complex applications better.
        Hence, as part of the Enhanced ER Model, along with other improvements, three new concepts were added to the
        existing ER Model, they were:
            1. Generalization
            2. Specialization
            3. Aggregration
        Generalization
        Generalization is a bottom-up approach in which two lower level entities combine to form a higher level entity. In
        generalization, the higher level entity can also combine with other lower level entities to make further higher level
        entity.
        It's more like Superclass and Subclass system, but the only difference is the approach, which is bottom-up. Hence,
        entities are combined to form a more generalised entity, in other words, sub-classes are combined to form a super-
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                             25
                                                www.Poriyaan.in
class.
        For example, Saving and Current account types entities can be generalised and an entity with name Account can be
        created, which covers both.
        Specialization
        Specialization is opposite to Generalization. It is a top-down approach in which one higher level entity can be
        broken down into two lower level entity. In specialization, a higher level entity may not have any lower-level entity
        sets, it's possible.
        Aggregation
        Aggregation is a process when relation between two entities is treated as a single entity.
        In the diagram above, the relationship between Center and Course together, is acting as an Entity, which is in
        relationship with another entity Visitor. Now in real world, if a Visitor or a Student visits a Coaching Center, he/she
        will never enquire about the center only or just about the course, rather he/she will ask enquire about both.
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                               26
                                                 www.Poriyaan.in
        It is very convenient to design the database using the ER Model by creating an ER diagram and later on converting
        it into relational model to design your tables.
        Not all the ER Model constraints and components can be directly transformed into relational model, but an
        approximate schema can be derived.
        Few examples of ER diagrams and convert it into relational model schema, hence creating tables in RDBMS.
        Entity becomes Table
        Entity in ER Model is changed into tables, or we can say for every Entity in ER model, a table is created in
        Relational Model.
        And the attributes of the Entity gets converted to columns of the table.
        And the primary key specified for the entity in the ER model, will become the primary key for the table in
        relational model.
        For example, for the below ER Diagram in ER Model,
        A table with name Student will be created in relational model,                                which     will    have    4
        columns, id, name, age, address and id will be the primary key for this table.
        Table:Student
        As discussd above, entity gets mapped to table, hence we will create table for Teacher and a table for Student with
        all the attributes converted into columns.
        Now, an additional table will be created for the relationship, for example StudentTeacher or give it any name you
        like. This table will hold the primary key for both Student and Teacher, in a tuple to describe the relationship,
        which teacher teaches which student.
        If there are additional attributes related to this relationship, then they become the columns for this table, like subject
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                                  27
                                                www.Poriyaan.in
        name.
        Also proper foreign key constraints must be set for all the tables.
        Functional Dependency
        The functional dependency is a relationship that exists between two attributes. It typically exists between the
        primary key and non-key attribute within a table.
        X→Y
        The left side of FD is known as a determinant, the right side of the production is known as a dependent.
        For example:
        Assume we have an employee table with attributes: Emp_Id, Emp_Name, Emp_Address.
        Here Emp_Id attribute can uniquely identify the Emp_Name attribute of employee table because if we know the
        Emp_Id, we can tell that employee name associated with it.
        Functional dependency can be written as:
                                                      Emp_Id → Emp_Name
        Types of Functional dependency
        Normalization of Database
        Database Normalization is a technique of organizing the data in the database. Normalization is a systematic
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                       28
                                                 www.Poriyaan.in
        approach of decomposing tables to eliminate data redundancy(repetition) and undesirable characteristics like
        Insertion, Update and Deletion anomalies. It is a multi-step process that puts data into tabular form, removing
        duplicated data from the relation tables.
        Normalization is used for mainly two purposes,
        In the table above, we have data of 4 Computer Sci. students. As we can see, data for the fields branch, hod(Head
        of Department) and office_tel is repeated for the students who are in the same branch in the college, this is Data
        Redundancy.
        Insertion Anomaly
        Suppose for a new admission, until and unless a student opts for a branch, data of the student cannot be inserted, or
        else we will have to set the branch information as NULL.
        Also, if we have to insert data of 100 students of same branch, then the branch information will be repeated for all
        those 100 students.
        These scenarios are nothing but Insertion anomalies.
        Updation Anomaly
        What if Mr. X leaves the college? or is no longer the HOD of computer science department? In that case all the
        student records will have to be updated, and if by mistake we miss any record, it will lead to data inconsistency.
        This is Updation anomaly.
        Deletion Anomaly
        In our Student table, two different informations are kept together, Student information and Branch information.
        Hence, at the end of the academic year, if student records are deleted, we will also lose the branch information.
        This is Deletion anomaly.
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                             29
                                                www.Poriyaan.in
        Normalization Rule
        Normalization rules are divided into the following normal forms:
        1. First Normal Form
        2. Second Normal Form
        3. Third Normal Form
        4. BCNF
        5. Fourth Normal Form
        6. Fifth Normal Form
        First Normal Form (1NF)
        For a table to be in the First Normal Form, it should follow the following 4 rules:
            1. It should only have single(atomic) valued attributes/columns.
            2. Values stored in a column should be of the same domain
            3. All the columns in a table should have unique names.
            4. And the order in which data is stored, does not matter.
        Rules for First Normal Form
        The first normal form expects you to follow a few simple rules while designing your database, and they are:
        Rule 1: Single Valued Attributes
        Each column of your table should be single valued which means they should not contain multiple values. We
        will explain this with help of an example later, let's see the other rules for now.
        Rule 2: Attribute Domain should not change
        This is more of a "Common Sense" rule. In each column the values stored must be of the same kind or type.
        For example: If you have a column dob to save date of births of a set of people, then you cannot or you must
        not save 'names' of some of them in that column along with 'date of birth' of others in that column. It should
        hold only 'date of birth' for all the records/rows.
        Rule 3: Unique name for Attributes/Columns
        This rule expects that each column in a table should have a unique name. This is to avoid confusion at the time
        of retrieving data or performing any other operation on the stored data.
        If one or more columns have same name, then the DBMS system will be left confused.
        Rule 4: Order doesn't matters
        This rule says that the order in which you store the data in your table doesn't matter.
        EXAMPLE
        Create a table to store student data which will have student's roll no., their name and the name of subjects they
        have opted for.
        Here is the table, with some sample data added to it.
        The table already satisfies 3 rules out of the 4 rules, as all our column names are unique, we have stored data
        in the order we wanted to and we have not inter-mixed different type of data in columns.
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                         30
                                              www.Poriyaan.in
        But out of the 3 different students in our table, 2 have opted for more than 1 subject. And we have stored the
        subject names in a single column. But as per the 1st Normal form each column must contain atomic value.
        It's very simple, because all we have to do is break the values into atomic values.
        Here is our updated table and it now satisfies the First Normal Form.
                                                  roll_no Name subject
                                                       101 Akon         OS
                                                       101 Akon         CN
                                                       103 Ckon         Java
                                                       102 Bkon         C
                                                       102 Bkon         C++
        By doing so, although a few values are getting repeated but values for the subject column are now atomic for
        each record/row. Using the First Normal Form, data redundancy increases, as there will be many columns with
        same data in multiple rows but each row as a whole will be unique.
        Second Normal Form (2NF)
        For a table to be in the Second Normal Form,
        1. It should be in the First Normal form.
        2. And, it should not have Partial Dependency.
        Dependency
        Let's take an example of a Student table with columns student_id, name, reg_no(registration
        number), branch and address(student's home address).
                                       student_               reg_n      branc     addre
                                                    name
                                          id                  o          h         ss
        In this table, student_id is the primary key and will be unique for every row, hence we can use student_id to
        fetch any row of data from this table
        Even for a case, where student names are same, if we know the student_id we can easily fetch the correct
        record.
                                   student_id      name reg_no           branch      address
                                         10         Akon      07-WY         CSE        Kerala
                                         11         Akon      08-WY          IT        Gujarat
        Hence we can say a Primary Key for a table is the column or a group of columns(composite key) which can
        uniquely identify each record in the table.
        I can ask from branch name of student with student_id 10, and I can get it. Similarly, if I ask for name of
        student with student_id 10 or 11, I will get it. So all I need is student_id and every other column depends on it,
        or can be fetched using it.This is Dependency and we also call it Functional Dependency.
        Partial Dependency
        Now that we know what dependency is, we are in a better state to understand what partial dependency is.
        For a simple table like Student, a single column like student_id can uniquely identfy all the records in a table.
        But this is not true all the time. So now let's extend our example to see if more than 1 column together can act
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                          31
                                              www.Poriyaan.in
        as a primary key.
        Let's create another table for Subject, which will have subject_id and subject_name fields and subject_id will
        be the primary key.
                                                    subject_i subject_nam
                                                    d           e
                                                            1 Java
                                                            2 C++
                                                            3 Php
        Now we have a Student table with student information and another table Subject for storing subject
        information.
        Let's create another table Score, to store the marks obtained by students in the respective subjects. We will also
        be saving name of the teacher who teaches that subject along with marks.
                                                             subject_i
                              score_id student_id                         marks teacher
                                                             d
                                  1               10              1         70       Java Teacher
                                  2               10              2         75        C++ Teacher
                                  3               11              1         80       Java Teacher
        In the score table we are saving the student_id to know which student's marks are these and subject_id to
        know for which subject the marks are for.
        Together, student_id + subject_id forms a Candidate Key which can be the Primary key.
        To get me marks of student with student_id 10, can you get it from this table? No, because you don't know for
        which subject. And if I give you subject_id, you would not know for which student. Hence we need student_id
        + subject_id to uniquely identify any row.
        But where is Partial Dependency?
        Now if you look at the Score table, we have a column names teacher which is only dependent on the subject,
        for Java it's Java Teacher and for C++ it's C++ Teacher & so on.
        Now as we just discussed that the primary key for this table is a composition of two columns which
        is student_id & subject_id but the teacher's name only depends on subject, hence the subject_id, and has
        nothing to do with student_id.
        This is Partial Dependency, where an attribute in a table depends on only a part of the primary key and not on
        the whole key.
        How to remove Partial Dependency?
        There can be many different solutions for this, but out objective is to remove teacher's name from Score table.
        The simplest solution is to remove columns teacher from Score table and add it to the Subject table. Hence, the
        Subject table will become:
                                      subject_id subject_name                 teacher
                                          1              Java             Java Teacher
                                          2               C++              C++ Teacher
                                          3               Php              Php Teacher
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                          32
                                              www.Poriyaan.in
        And our Score table is now in the second normal form, with no partial dependency.
                                            score_ student_ subject_ mar
                                              id         id         id         ks
                                               1        10           1         70
                                               2        10           2         75
                                               3        11
        Student Table
                              student_i
                                              name       reg_no            branch        address
                                  d
                                 10           Akon       07-WY              CSE           Kerala
                                 11           Akon       08-WY               IT           Gujarat
                                 12           Bkon       09-WY               IT          Rajasthan
        Subject Table
                                    subject_id subject_name               teacher
                                        1          Java                 Java Teacher
                                          2             C++             C++ Teacher
                                          3             Php                Php Teacher
        Score Table
        In the Score table, we need to store some more information, which is the exam name and total marks, so let's
        add 2 more columns to the Score table.
                                                     student_i subject_i
                                          score_id                              marks
                                                          d           d
                                              1           10          1           70
                                              2           10          2           75
                                              3          11            1            80
        Transitive Dependency
        With exam_name and total_marks added to our Score table, it saves more data now. Primary key for the Score
        table is a composite key, which means it's made up of two attributes or columns → student_id + subject_id.
        The new column exam_name depends on both student and subject. For example, a mechanical engineering
        student will have Workshop exam but a computer science student won't. And for some subjects you have
        Practical exams and for some you don't. So we can say that exam_name is dependent on
        both student_id and subject_id.
        And what about our second new column total_marks? Does it depend on our Score table's primary key?
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                    33
                                              www.Poriyaan.in
        Well, the column total_marks depends on exam_name as with exam type the total score changes. For example,
        practicals are of less marks while theory exams are of more marks.
        But, exam_name is just another column in the score table. It is not a primary key or even a part of the primary
        key, and total_marks depends on it.
        This is Transitive Dependency. When a non-prime attribute depends on other non-prime attributes rather than
        depending upon the prime attributes or primary key.
        How to remove Transitive Dependency
        Again the solution is very simple. Take out the columns exam_name and total_marks from Score table and put
        them in an Exam table and use the exam_id wherever required.
        Score Table: In 3rd Normal Form
                                           student_i     subject_
                             score_id                                     marks          exam_id
                                               d            id
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                        34
                                             www.Poriyaan.in
        Well, in the table above student_id, subject together form the primary key, because
        using student_id and subject, we can find all the columns of the table.
        One more important point to note here is, one professor teaches only one subject, but one subject may have
        two different professors.
        Hence, there is a dependency between subject and professor here, where subject depends on the professor
        name.
        This table satisfies the 1st Normal form because all the values are atomic, column names are unique and all the
        values stored in a particular column are of same domain.
        This table also satisfies the 2nd Normal Form as there is no Partial Dependency.
        And, there is no Transitive Dependency, hence the table also satisfies the 3rd Normal Form.
        But this table is not in Boyce-Codd Normal Form.
        Why this table is not in BCNF?
        In the table above, student_id, subject form primary key, which means subject column is a prime attribute.
        But, there is one more dependency, professor → subject.
        And while subject is a prime attribute, professor is a non-prime attribute, which is not allowed by BCNF.
        How to satisfy BCNF?
        To make this relation(table) satisfy BCNF, we will decompose this table into two tables, student table
        and professor table.
        Below we have the structure for both the tables.
        Student Table
          student_id           p_id
              101                1
              101                2
         Professor Table
             p_id       professor       subject
               1          P.Java          Java
               2           P.Cpp          C++
        And now, this relation satisfy Boyce-Codd Normal Form.
        Fourth Normal Form (4NF)
        A table is said to be in the Fourth Normal Form when,
            1. It is in the Boyce-Codd Normal Form.
            2. And, it doesn't have Multi-Valued Dependency.
        Multi-valued Dependency
        A table is said to have multi-valued dependency, if the following conditions are true,
             1. For a dependency A → B, if for a single value of A, multiple value of B exists, then the table may have
                 multi-valued dependency.
             2. Also, a table should have at-least 3 columns for it to have a multi-valued dependency.
             3. And, for a relation R(A,B,C), if there is a multi-valued dependency between, A and B, then B and C
                 should be independent of each other.
        If all these conditions are true for any relation(table), it is said to have multi-valued dependency.
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                       35
                                             www.Poriyaan.in
        Example
        Below we have a college enrolment table with columns s_id, course and hobby.
                                                               cours
                                                   s_id                    hobby
                                                                  e
                                                               Scienc
                                                     1                     Cricket
                                                                  e
                                                     1         Maths       Hockey
                                                     2           C#        Cricket
                                                     2          Php        Hockey
        From the table above, student with s_id 1 has opted for two courses, Science and Maths, and has two
        hobbies, Cricket and Hockey.
        You must be thinking what problem this can lead to, right?
        Well the two records for student with s_id 1, will give rise to two more records, as shown below, because for
        one student, two hobbies exists, hence along with both the courses, these hobbies should be specified.
                                                s_id          course         hobby
                                                  1           Science        Cricket
                                                  1            Maths         Hockey
                                                  1           Science        Hockey
                                                  1            Maths         Cricket
        And, in the table above, there is no relationship between the columns course and hobby. They are independent
        of each other.
        So there is multi-value dependency, which leads to un-necessary repetition of data and other anomalies as
        well.
        How to satisfy 4th Normal Form?
        To make the above relation satify the 4th normal form, we can decompose the table into 2 tables.
        CourseOpted Table
             s_id           course
              1             Science
              1              Maths
              2               C#
              2               Php
        Hobbies Table,
               s_id             hobby
                 1              Cricket
                 1             Hockey
                 2              Cricket
                 2             Hockey
        Now this relation satisfies the fourth normal form.
        A table can also have functional dependency along with multi-valued dependency. In that case, the
        functionally dependent columns are moved in a separate table and the multi-valued dependent columns are
        moved to separate tables.
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                     36
                                               www.Poriyaan.in
The above table can be decomposed into the following three tables; therefore it is not in 5NF:
        <EmployeeSkills>
                               EmpName                            EmpSkills
                               Tom                                Networking
                               Harry                              Web Development
                               Katie                              Programming
        <EmployeeJob>
                               EmpName                            EmpJob
                               Tom                                EJ001
                               Harry                              EJ002
                               Katie                              EJ002
        <JobSkills>
                               EmpSkills                          EmpJob
                               Networking                         EJ001
                               Web Development                    EJ002
                               Programming                        EJ002
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                            37
                                               www.Poriyaan.in
        The above relations have join dependency, so they are not in 5NF. That would mean that a join relation of the
        above three relations is equal to our original relation <Employee>.
        In above table, Rose takes both Mathematics and Physics class for Semester 1, but she does not take Physics
        class for Semester 2. In this case, combination of all these 3 fields is required to identify a valid data. Imagine
        we want to add a new class - Semester3 but do not know which Subject and who will be taking that subject.
        We would be simply inserting a new entry with Class as Semester3 and leaving Lecturer and subject as NULL.
        As we discussed above, it's not a good to have such entries. Moreover, all the three columns together act as a
        primary key, we cannot leave other two columns blank!
        Hence we have to decompose the table in such a way that it satisfies all the rules till 4NF and when join them
        by using keys, it should yield correct record. Here, we can represent each lecturer's Subject area and their
        classes in a better way. We can divide above table into three - (SUBJECT, LECTURER), (LECTURER,
        CLASS), (SUBJECT, CLASS)
        Now, each of combinations is in three different tables. If we need to identify who is teaching which subject to
        which semester, we need join the keys of each table and get the result.
        For example, who teaches Physics to Semester 1, we would be selecting Physics and Semester1 from table 3
        above, join with table1 using Subject to filter out the lecturer names. Then join with table2 using Lecturer to
        get correct lecturer name. That is we joined key columns of each table to get the correct data. Hence there is no
        lose or new data - satisfying 5NF condition.
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                           38
                                              www.Poriyaan.in
                                              TRANSACTION CONCEPTS.
         A transaction is a collection of operations that forms single logical unit of work.
         Simple Transaction Example
         1. Read your account balance
         2. Deduct the amount from your balance
         3. Write the remaining balance to your account
         4. Read your friend’s account balanace
         5. Add the amount to his account balance
         6. Write the new updated balance to his account
         This whole set of operations can be called a transaction
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                         39
                                               www.Poriyaan.in
Page 2
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                         40
                                              www.Poriyaan.in
                 5.       B := B + 50
                 6.       write(B)
         Example of Fund Transfer
            • Atomicity requirement
                      – if the transaction fails after step 3 and before step 6, money will be “lost” leading to an
                          inconsistent database state
                      – the system should ensure that updates of a partially executed transaction are not reflected in
                          the database
            • Durability requirement
                      – once the user has been notified that the transaction has completed, the updates to the
                          database by the transaction must persist even if there are software or hardware failures.
            • Isolation requirement — if between steps 3 and 6, another transaction T2 is allowed to access the
                 partially updated database, it will see an inconsistent database        T1                         T2
         1.      read(A)
         2.      A := A – 50
         3.      write(A)
                                   read(A), read(B), print(A+B)
         4.      read(B)
         5.      B := B + 50
         6.      write(B)
            • Isolation can be ensured trivially by running transactions serially
                      – that is, one after the other.
                                                           SCHEDULES
         • Schedule – a sequences of instructions that specify the chronological order in which instructions of
            concurrent transactions are executed
                 – a schedule for a set of transactions must consist of all instructions of those transactions
                 – must preserve the order in which the instructions appear in each individual transaction.
         • Serial Schedule
                 It is a schedule in which transactions are aligned in such a way that one transaction is executed
            first. When the first transaction completes its cycle, then the next transaction is executed. Transactions
            are ordered one after the other. This type of schedule is called a serial schedule, as transactions are
            executed in a serial manner.
            Schedule 1
            • Let T1 transfer 50 from A to B, and T2 transfer 10% of the balance from A to B.
            • A serial schedule in which T1 is followed by T2 :
Schedule 2
Page 3
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                      41
                                              www.Poriyaan.in
         Schedule 3
            • Let T1 and T2 be the transactions defined previously. The following schedule is not a serial
               schedule, but it is equivalent to Schedule 1.
         Schedule 4
         The following concurrent schedule does not preserve the value of (A + B ).
                                                      SERIALIZABILITY
                 When multiple transactions are being executed by the operating system in a multiprogramming
         environment, there are possibilities that instructions of one transactions are interleaved with some other
         transaction.
             • Serializability is the classical concurrency scheme.
Page 4
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                   42
                                              www.Poriyaan.in
            •    It ensures that a schedule for executing concurrent transactions is equivalent to one that executes
                 the transactions serially in some order.
         erializable schedule
                 If a schedule is equivalent to some serial schedule then that schedule is called Serializable
         schedule
         Let us consider a schedule S. What the schedule S says ?
         Read A after updation.
         Read B before updation.
Let us consider 3 schedules S1, S2, and S3. We have to check whether they are serializable with S or not ?
         Types of Serializability
                -Conflict Serializability
Page 5
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                    43
                                              www.Poriyaan.in
-View Serializability
         Conflict Serializable
                   Any given concurrent schedule is said to be Conflict Serializable if and only if it is Conflict
         equivalent to one of the possible serial schedule.
         Two schedules would be conflicting if they have the following properties
                       – Both belong to separate transactions.
                       – Both accesses the same data item.
                       – At least one of them is "write" operation.
         Conflicting Instructions
         Instructions li and lj of transactions Ti and Tj respectively, conflict if they are operations by different
         transaction on the same data item, and at least one of these instruction is write operation.
            1. li = read(Q), lj = read(Q). li and lj don’t conflict.
            2. li = read(Q), lj = write(Q). They conflict.
            3. li = write(Q), lj = read(Q). They conflict
            4. li = write(Q), lj = write(Q). They conflict
         Two schedules having multiple transactions with conflicting operations are said to be conflict equivalent
         if and only if
                       – Both the schedules contain the same set of Transactions.
                       – The order of conflicting pairs of operation is maintained in both the schedules.
              – If a schedule S can be transformed into a schedule S´ by a series of swaps of non-conflicting
                   instructions, we say that S and S´ are conflict equivalent.
              – We say that a schedule S is conflict serializable if it is conflict equivalent to a serial schedule
         Schedule 3 can be transformed into Schedule 6, a serial schedule where T2 follows T1, by series of swaps
         of non-conflicting instructions. Therefore Schedule 3 is conflict serializable.
         Schedule 3
Schedule 6
Page 6
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                    44
                                              www.Poriyaan.in
         View Serializable
                 Any given concurrent schedule is said to be View Serializable if and only if it is View equivalent to
         one of the possible serial schedule.
         Let S and S´ be two schedules with the same set of transactions. S and S´ are view equivalent if the
         following three conditions are met, for each data item Q,
                     1. If in schedule S, transaction Ti reads the initial value of Q, then in schedule S’ also
                        transaction Ti must read the initial value of Q.
                     2. If in schedule S, transaction Ti executes read(Q), and that value was produced by
                        transaction Tj (if any), then in schedule S’ also transaction Ti must read the value of Q that
                        was produced by the same write(Q) operation of transaction Tj .
                     3. The transaction (if any) that performs the final write(Q) operation in schedule S must also
                        perform the final write(Q) operation in schedule S’.
                                                 CONCURRENCY CONTROL
         Process of managing simultaneous execution of transactions in a shared database, to ensure the
         serializability of transactions, is known as concurrency control.
             • Process of managing simultaneous operations on the database without having them interfere with
                 one another.
             • Prevents interference when two or more users are accessing database simultaneously and at least
Page 7
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                      45
                                             www.Poriyaan.in
         Example:
            • T1 updates balx to £200 but it aborts, so balx should be back at original value of £100.
            • T2 has read new value of balx (£200) and uses value as basis of £10 reduction, giving a new
               balance of £190, instead of £90.
            • Problem avoided by preventing T2 from reading balx until after T1 commits or aborts.
Page 8
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                 46
                                               www.Poriyaan.in
         Example:
             • T6 is totaling balances of account x (£100), account y (£50), and account z (£25).
             • Meantime, T5 has transferred £10 from balx to balz, so T6 now has wrong result (£10 too high).
             • Problem avoided by preventing T6 from reading balx and balz until after T5 completed updates.
         Concurrency control techniques
                Some of the main techniques used to control the concurrent execution of transaction are based on
         the concept of locking the data items
                                                  LOCKING PROTOCOLS
         A lock is a variable associated with a data item that describe the statues of the item with respect to possible
         operations that can be applied to it.
         Locking is an operation which secures
                 (a) permission to Read
Page 9
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                        47
                                              www.Poriyaan.in
         Lock Manager:
            • Managing locks on data items.
         Lock table:
            • Lock manager uses it to store the identify of transaction locking a data item, the data item, lock
                mode and pointer to the next data item locked. One simple way to implement a lock table is
                through linked list
         Types of lock
                    o Binary lock
                    o Read/write(shared / Exclusive) lock
         Binary lock
                    – It can have two states (or) values 0 and 1.
                                 0 – unlocked
                                 1 - locked
                    – Lock value is 0 then the data item can accessed when requested.
                    – When the lock value is 1,the item cannot be accessed when requested.
            • Lock_item(x)
                B : if lock(x) = 0 ( * item is unlocked * )
                 then lock(x)       1
                          else begin
                   wait ( until lock(x) = 0 )
                   goto B;
                 end;
            • Unlock_item(x)
                B : if lock(x)=1 ( * item is locked * )
                   then lock(x)        0
                   else
                   printf (‘ already is unlocked ‘)
                   goto B;
                   end;
         Read / write(shared/exclusive) lock
Page 10
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                48
                                              www.Poriyaan.in
         Read_lock
               - its also called shared-mode lock
               - If a transaction Ti has obtain a shared-mode lock on item X, then Ti can read, but cannot write ,X.
          - Outer transactions are also allowed to read the data item but cannot write.
         Read_lock(x)
         B : if lock(x) = “unlocked” then
                             begin
                             lock(x)       “ read_locked”
                             no_of_read(x)       1
                             else if
                             lock(x) = “read_locked”
                             then
                             no_of_read(x)        no_of_read(x) +1
                             else begin
                             wait (until lock(x) = “unlocked”
                             goto B;
                             end;
         Write_lock(x)
         B : if lock(x) = “unlocked” then
                  begin
                  lock(x)       “write_locked”
                  else if
                  lock(x) = “write_locked”
                  wait ( until lock(x) = “unlocked” )
                  else begin
                  lock(x)=“read_locked” then
                  wait ( until lock(x) = “unlocked” )
             end;
         Unlock(x)
         If lock(x) = “write_locked” then
         Begin
         Lock(x)       “unlocked”
         Else if
         lock(x) = “read_locked” then
         Begin
         No_of_read(x)          no_of_read(x) - 1
         If ( no_of_read(x) = 0 ) then
         Begin
         Lock(x)       “unlocked”
         End
                                            TWO PHASE LOCKING PROTOCOL
         This protocol requires that each transaction issue lock and unlock request in two phases
              • Growing phase
              • Shrinking phase
         Growing phase
Page 11
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                    49
                                              www.Poriyaan.in
                      • During this phase new locks can be occurred but none can be released
         Shrinking phase
                      • During which existing locks can be released and no new locks can be occurred
         Types
             • Strict two phase locking protocol
             • Rigorous two phase locking protocol
         Strict two phase locking protocol
                 This protocol requires not only that locking be two phase, but also all exclusive locks taken by a
         transaction be held until that transaction commits.
         Rigorous two phase locking protocol
                 This protocol requires that all locks be held until all transaction commits.
         Consider the two transaction T1 and T2
         T1 : read(a1);
                   read(a2);
                    …….
                    read(an);
               write(a1);
         T2: read(a1);
                  read(a2);
             display(a1+a1);
         Lock conversion
             • Lock Upgrade
             • Lock Downgrade
         Lock upgrade:
             • Conversion of existing read lock to write lock
             • Take place in only the growing phase
         if Ti has a read-lock (X) and Tj has no read-lock (X) (i  j) then
                  convert read-lock (X) to write-lock (X)
          else
                     force Ti to wait until Tj unlocks X
         Lock downgrade:
             • conversion of existing write lock to read lock
             • Take place in only the shrinking phase
         Ti has a write-lock (X) (*no transaction can have any lock on X*)
                          convert write-lock (X) to read-lock (X)
Page 12
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                   50
                                              www.Poriyaan.in
Transaction State
            •   Active – the initial state; the transaction stays in this state while it is executing
            •   Partially committed – after the final statement has been executed.
            •   Failed -- after the discovery that normal execution can no longer proceed.
            •   Aborted – after the transaction has been rolled back and the database restored to its state prior to
                the start of the transaction. Two options after it has been aborted:
                    o restart the transaction
                    o kill the transaction
            •   Committed – after successful completion
         Log
            •   Log is a history of actions executed by a database management system to guarantee ACID
                properties over crashes or hardware failures.
            • Physically, a log is a file of updates done to the database, stored in stable storage.
         Log rule
            – A log records for a given database update must be physically written to the log, before the update
                physically written to the database.
            – All other log record for a given transaction must be physically written to the log, before the commit
                log record for the transaction is physically written to the log.
            – Commit processing for a given transaction must not complete until the commit log record for the
                transaction is physically written to the log.
         System log
                    – [ Begin transaction ,T ]
                    – [ write_item , T, X , oldvalue,newvalue]
                    – [read_item,T,X]
                    – [commit,T]
                    – [abort,T]
         TWO - PHASE COMMIT
            • Assumes fail-stop model – failed sites simply stop working, and do not cause any other harm, such
                as sending incorrect messages to other sites.
            • Execution of the protocol is initiated by the coordinator after the last step of the transaction has
                been reached.
            • The protocol involves all the local sites at which the transaction executed
            • Let T be a transaction initiated at site Si, and let the transaction coordinator at Si be Ci
         Phase 1: Obtaining a Decision (prepare)
            • Coordinator asks all participants to prepare to commit transaction Ti.
Page 13
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                    51
                                              www.Poriyaan.in
                     – Ci adds the records <prepare T> to the log and forces log to stable storage
                     – sends prepare T messages to all sites at which T executed
             • Upon receiving message, transaction manager at site determines if it can commit the transaction
                     – if not, add a record <no T> to the log and send abort T message to Ci
                     – if the transaction can be committed, then:
                     – add the record <ready T> to the log
                     – force all records for T to stable storage
                     – send ready T message to Ci
         Phase 2: Recording the Decision (commit)
             • T can be committed of Ci received a ready T message from all the participating sites: otherwise T
                 must be aborted.
             • Coordinator adds a decision record, <commit T> or <abort T>, to the log and forces record onto
                 stable storage. Once the record stable storage it is irrevocable (even if failures occur)
             • Coordinator sends a message to each participant informing it of the decision (commit or abort)
             • Participants take appropriate action locally.
         Handling of Failures - Site Failure
         When site Si recovers, it examines its log to determine the fate of
         transactions active at the time of the failure.
             • Log contain <commit T> record: site executes redo (T)
             • Log contains <abort T> record: site executes undo (T)
             • Log contains <ready T> record: site must consult Ci to determine the fate of T.
                     – If T committed, redo (T)
                     – If T aborted, undo (T)
             • The log contains no control records concerning T replies that Sk failed before responding to the
                 prepare T message from Ci
                     – since the failure of Sk precludes the sending of such a
                         response C1 must abort T
                     – Sk must execute undo (T)
Page 14
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                     52
                                               www.Poriyaan.in
                            • No harm results, but sites may still have to wait for decision from coordinator.
            •   The coordinator and the sites are in the same partition as the coordinator think that the sites in the
                other partition have failed, and follow the usual commit protocol.
                            • Again, no harm results
                                                        DEADLOCK
                System is deadlocked if there is a set of transactions such that every transaction in the set is waiting
         for another transaction in the set.
         Consider the following two transactions:
                         T1: write (A)           T2: write(A)
                               write(B)                write(B)
                                                           lock-X on B
                                                           write (B)
                                                           wait for lock-X on A
         Deadlock Handling
         Deadlock prevention protocol
            Ensure that the system will never enter into a deadlock state.
         Some prevention strategies :
         Approach1
                     – Require that each transaction locks all its data items before it begins execution either all are
                         locked in one step or none are locked.
                     – Disadvantages
                             • Hard to predict ,before transaction begins, what data item need to be locked.
                             • Data item utilization may be very low.
         Approach2
                     – Assign a unique timestamp to each transaction.
                     – These timestamps only to decide whether a transaction should wait or rollback.
                     schemes:
                         - wait-die scheme
                         - wound-wait scheme
         wait-die scheme
                  - non preemptive technique
                    When transaction Ti request a data item currently held by Tj, Ti is allowed to wait only if it has
         a timestamp smaller than that of Tj. otherwise ,Ti rolled back(dies)
                     – older transaction may wait for younger one to release data item. Younger transactions
Page 15
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                        53
                                              www.Poriyaan.in
                        never wait for older ones; they are rolled back instead.
                    –   A transaction may die several times before acquiring needed data item
         Example.
                    • Transaction T1,T2,T3 have time stamps 5,10,15,respectively.
                    • if T 1 requests a data item held by T2,then T1 will wait.
                    • If T3 request a data item held by T2,then T3 will be rolled back.
         .wound-wait scheme
                  - Preemptive technique
             - When transaction Ti requests a data item currently held by Tj,Ti is allowed to wait only if it has a
         timestamp larger than that of Tj. Otherwise Tj is rolled back
                    – Older transaction wounds (forces rollback) of younger transaction instead of waiting for it.
                        Younger transactions may wait for older ones.
         Example
                    • Transaction T1,T2,T3 have time stamps 5,10,15,respectively.
                    • if T1 requests a data item held by T2,then the data item will be preempted from T 2,and T2
                        will be rolled back.
                    • If T3 requests a data item held by T2,then T3 will wait.
         Deadlock Detection
            - Deadlocks can be described as a wait-for graph, which consists of a pair G = (V,E),
                    – V is a set of vertices
                    – E is a set of edges
            - If Ti  Tj is in E, then there is a directed edge from Ti to Tj, implying that Ti is waiting for Tj to
                release a data item.
            - The system is in a deadlock state if and only if the wait-for graph has a cycle. Must invoke a
                deadlock-detection algorithm periodically to look for cycles.
         Wait-for graph without a cycle
Page 16
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                    54
                                              www.Poriyaan.in
                      – Rollback
                      – Starvation
         Selection of victim
                    • Set of deadlocked transations,must determine which transaction to roll back to break the
                       deadlock.
                     • Consider the factor minimum cost
         Rollback
             - once we decided that a particular transaction must be rolled back, must determine how far this
                 transaction should be rolled back
             - Total rollback
             - Partial rollback
         Starvation
                 Ensure that a transaction can be picked as victim only a finite number of times.
         Intent locking
             - Intent locks are put on all the ancestors of a node before that node is locked explicitly.
             - If a node is locked in an intention mode, explicit locking is being done at a lower level of the tree.
         Types of Intent Locking
             - Intent shared lock(IS)
             - Intent exclusive lock(IX)
             - Shared lock (S)
             - Shared Intent exclusive lock (SIX)
             - Exclusive lock (X)
         Intent shared lock(IS)
                      • If a node is locked in indent shared mode, explicit locking is being done at a lower level of
                          the tree, but with only shared-mode lock
                      • Suppose the transaction T1 reads record ra2 in file Fa. Then,T1 needs to lock the database,
                          area A1,and Fa in IS mode, and finally lock ra2 in S mode.
         Intent exclusive lock(IX)
                 If a node is locked in intent locking is being done at a lower level of the tree, but with exclusive
         mode or shared-mode locks.
                      – Suppose the transaction T2 modifies record ra9 in file Fa. Then,T2 needs to lock the database,
                          area A1,and Fa in IX mode, and finally to lock ra9 in X mode.
         Shared Intent exclusive lock (SIX)
                 If the node is locked in Shared Intent exclusive mode, the subtree rooted by that node is locked
         explicitly in shared mode, and that explicit locking is being done at lower level with exclusive mode.
         Shared lock (S)
                 -T can tolerate concurrent readers but not concurrent updaters in R.
         Exclusive lock (X)
                 -T cannot tolerate any concurrent access to R at all.
         Lock compatibility
Page 17
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                      55
                                             www.Poriyaan.in
                                                           Tran 2
                                              NL    IS   IX   S           SIX  X
                                    T NL      Yes Yes Yes Yes             Yes Yes
                                    r  IS     Yes Yes Yes Yes             Yes No
                                    a
                                    n
                                       IX     Yes Yes Yes No               No No
                                        S     Yes Yes No Yes               No No
                                    1 SIX     Yes Yes No No               No   No
                                        X     Yes No No No No No
Page 18
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                 56
                                              www.Poriyaan.in
         System failure – do not physically damage the DB Eg: power shut down
         Media failure-cause damage to the DB. Eg: head crash
         ARIES Recovery Algorithm
            - ARIES-Algorithm for Recovery and Isolation Exploiting Semantics
            - ARIES recovery involves three passes
                Analysis pass: Determines the REDO and UNDO lists.
                Redo pass: Repeats history, redoing all actions from REDO List
                Undo pass: Rolls back all incomplete transactions
            -   The system failure occurred at time Tf , the most recent check point prior to the time T f was taken
                at a time Tf
            -    Start with two list of transaction the UNDO and REDO list
            -    search forward through the log starting from check point.
            -    if begin transaction log record is found for transaction(T) add T to UNDO list.
            -    if commit log record is found for transaction(T),add T to REDO list
            -    when the end of log record is reached the UNDO and REDO list is identified
                UNDO            REDO
                     T3             T2
                     T5             T4
         SAVE POINTS
             - It is possible for a transaction to create a savepoint.
             - It is used to store intermediate results
         So that it will rollback to a previously established savepoint whenever any recovery process starts.
         Create: Savepoint <savepoint_name>;
         Rollback: Rollback to <savepoint_name>;
         Drop: Release <savepoint_name>;
         SQL
         COMMIT: Used to made the changes permanently in the Database.
         SAVEPOINT: Used to create a savepoint or a reference point.
Page 19
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                    57
                                              www.Poriyaan.in
Page 20
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                  58
                                                 www.Poriyaan.in
         There is no parity checking of data. So if data in one drive gets corrupted then all the data would be lost. Thus RAID
         0 does not support data recovery Spanning is another term that is used with RAID level 0 because the logical disk
         will span all the physical drives. RAID 0 implementation requires minimum 2 disks.
         Advantages
              I/O performance is greatly improved by spreading the I/O load across many channels & drives.
              Best performance is achieved when data is striped across multiple controllers with only one driver per
                 controller
         Disadvantages
              It is not fault-tolerant, failure of one drive will result in all data in an array being lost
         RAID Level 1: Mirroring (or shadowing)
              Also known as disk mirroring, this configuration consists of at least two drives that duplicate the storage of
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                               59
                                                 www.Poriyaan.in
         RAID Level 2:
         This configuration uses striping across disks, with some disks storing error checking and correcting (ECC)
         information. It has no advantage over RAID 3 and is no longer used.
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                           60
                                                www.Poriyaan.in
         RAID Level 5:
             RAID 5 uses striping as well as parity for redundancy. It is well suited for heavy read and low write
               operations.
             Block-Interleaved Distributed Parity; partitions data and parity among all N + 1 disks, rather than storing
               data in N disks and parity in 1 disk.
         RAID Level 6:
             This technique is similar to RAID 5, but includes a second parity scheme that is distributed across the drives
               in the array. The use of additional parity allows the array to continue to function even if two disks fail
               simultaneously. However, this extra protection comes at a cost.
             P+Q Redundancy scheme; similar to Level 5, but stores extra redundant information to guard against
               multiple disk failures.
                       - Better reliability than Level 5 at a higher cost; not used as widely.
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                            61
                                                  www.Poriyaan.in
                                                            File Organization
                The database is stored as a collection of files.
                Each file is a sequence of records.
                A record is a sequence of fields.
                Classifications of records
                                   – Fixed length record
                                   – Variable length record
              Fixed length record approach:
                          Assume record size is fixed each file has records of one particular type only different files are used
                          for different relations
         Simple approach
             - Record access is simple
         Example pseudo code
           type account = record
                             account_number char(10);
                             branch_name char(22);
                             balance numeric(8);
                           end
         Total bytes 40 for a record
         Two problems
                           - Difficult to delete record from this structure.
                           - Some record will cross block boundaries, that is part of the record will be stored in one block and
         part in another. It would require two block accesses to read or write
         Reuse the free space alternatives:
                      – move records i + 1, . . ., n to n i, . . . , n – 1
                      – do not move records, but link all free records on a
                           free list
                      – Move the final record to deleted record place.
         Free Lists
              Store the address of the first deleted record in the file header.
              Use this first record to store the address of the second deleted record, and so on
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                                62
                                                 www.Poriyaan.in
         Variable-Length Records
         Byte string representation
             Attach an end-of-record () control character to the end of each record
             Difficulty with deletion
                       0       perryridge          A-102         400          A-201        900          
         Disadvantage
              It is not easy to reuse space occupied formerly by deleted record.
              There is no space in general for records grows longer
         Slotted Page Structure
Pointer Method
              A variable-length record is represented by a list of fixed-length records, chained together via pointers.
              Can be used even if the maximum record length is not known.
         Disadvantage to pointer structure; space is wasted in all records except the first in a a chain.
         Solution is to allow two kinds of block in file:
              Anchor block – contains the first records of chain
              Overflow block – contains records other than those that are the first records of chains.
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                        63
                                                  www.Poriyaan.in
                                         Search-key             pointer
               Index files are typically much smaller than the original file
               Two basic kinds of indices:
                      – Ordered indices: search keys are stored in sorted order
                      – Hash indices: search keys are distributed uniformly across “buckets” and by using a “hash
                          function” the values are determined.
         Ordered Indices
             In an ordered index, index entries are stored sorted on the search key value.
             Primary index: in a sequentially ordered file, the index whose search key specifies the sequential order of
                the file.
             Secondary index: an index whose search key specifies an order different from the sequential order of the
                file.
         Types of Ordered Indices
             Dense index
             Sparse index
         Dense Index Files
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                         64
                                                 www.Poriyaan.in
 Dense index — Index record appears for every search-key value in the file.
         Multilevel Index
             If primary index does not fit in memory, access becomes expensive.
             To reduce number of disk accesses to index records, treat primary index kept on disk as a sequential file and
                construct a sparse index on it.
                     – outer index – a sparse index of primary index
                     – inner index – the primary index file
             If even outer index is too large to fit in main memory, yet another level of index can be created, and so on.
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                           65
                                                  www.Poriyaan.in
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                                 66
                                                  www.Poriyaan.in
                Disadvantage of indexed-sequential files: performance degrades as file grows, since many overflow blocks
                 get created. Periodic reorganization of entire file is required.
                Advantage of B+-tree index files: automatically reorganizes itself with small, local, changes, in the face of
                 insertions and deletions. Reorganization of entire file is not required to maintain performance.
                Disadvantage of B+-trees: extra insertion and deletion overhead, space overhead.
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                               67
                                                  www.Poriyaan.in
             Non-leaf nodes other than root must have between 3 and 5 children ((n/2 and n with n =5).
             Root must have at least 2 children.
         Observations about B+-trees
             Since the inter-node connections are done by pointers, “logically” close blocks need not be “physically”
                close.
             The B+-tree contains a relatively small number of levels thus searches can be conducted efficiently.
             Insertions and deletions to the main file can be handled efficiently.
         Updates on B+-Trees: Insertion
             Find the leaf node in which the search-key value would appear
             If the search-key value is already there in the leaf node, record is added to file and if necessary a pointer is
                inserted into the bucket.
             If the search-key value is not there, then add the record to the main file and create a bucket if
                necessary.Then:
                    – If there is room in the leaf node, insert (key-value, pointer) pair in the leaf node otherwise, split the
                        node.
         Example: B+-Tree before and after insertion of “Clearview”
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                               68
                                                  www.Poriyaan.in
             •   The removal of the leaf node containing “Downtown” did not result in its parent having too little pointers.
                 So the cascaded deletions stopped with the deleted leaf node’s parent.
         Deletion of “Perryridge” from result of previous example
            • Node with “Perryridge” becomes empty and merged with its sibling.
            • Root node then had only one child, and was deleted and its child became the new root node
         B+-Tree File Organization
            • The leaf nodes in a B+-tree file organization store records, instead of pointers.
            • Since records are larger than pointers, the maximum number of records that can be stored in a leaf node is
                less than the number of pointers in a nonleaf node.
            • Leaf nodes are still required to be half full.
            • Insertion and deletion are handled in the same way as insertion and deletion of entries in a B+-tree index.
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                              69
                                                  www.Poriyaan.in
                                                               HASHING
             •   Hashing is an effective technique to calculate the direct location of a data record on the disk without using
                 index structure.
             • Hashing uses hash functions with search keys as parameters to generate the address of a data record.
         Hash Organization
         Bucket
                         A hash file stores data in bucket format. Bucket is considered a unit of storage. A bucket typically
         stores one complete disk block, which in turn can store one or more records.
         Hash Function
                          A hash function, h, is a mapping function that maps all the set of search-keys K to the address
         where actual records are placed. It is a function from search keys to bucket addresses.
              Worst hash function maps all search-key values to the same bucket.
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                              70
                                                www.Poriyaan.in
                An ideal hash function is uniform, i.e., each bucket is assigned the same number of search-key values from
                 the set of all possible values.
                Ideal hash function is random, so each bucket will have the same number of records.
         Types
                    • Static Hashing
                    • Dynamic Hashing
         Static Hashing
              In static hashing, when a search-key value is provided, the hash function always computes the same address.
              For example, if mod-4 hash function is used, then it shall generate only 5 values. The output address shall
                 always be same for that function.
              The number of buckets provided remains unchanged at all times.
         Example of Hash File Organization
              There are 10 buckets,
              The hash function returns the sum of the binary representations of the characters modulo 10
                    – E.g. h(Perryridge) = 5 h(Round Hill) = 3 h(Brighton) = 3
         Operation
             Insertion − When a record is required to be entered using static hash, the hash function h computes the
                bucket address for search key K, where the record will be stored.
                        Bucket address = h(K)
             Search − When a record needs to be retrieved, the same hash function can be used to retrieve the address of
                the bucket where the data is stored.
             Delete − This is simply a search followed by a deletion operation.
         Handling of Bucket Overflows
             Bucket overflow can occur because of
                    – Insufficient buckets
                    – Skew in distribution of records. This can occur due to :
                            • multiple records have same search-key value
             Although the probability of bucket overflow can be reduced, it cannot be eliminated; it is handled by using
                overflow buckets.
             Overflow chaining – the overflow buckets of a given bucket are chained together in a linked list.
             Above scheme is called closed hashing.
                    – An alternative, called open hashing, which does not use overflow buckets, is not suitable for
                        database applications.
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                           71
                                                 www.Poriyaan.in
         Hash Indices
            • Hashing can be used not only for file organization, but also for index-structure creation.
            • A hash index organizes the search keys, with their associated record pointers, into a hash file structure.
            • Hash indices are always secondary indices
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                           72
                                                www.Poriyaan.in
                                – The number of buckets also changes dynamically due to coalescing and splitting of buckets.
         General Extendable Hash
         In this structure, i2 = i3 = i, whereas i1 = i – 1
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                            73
                                                  www.Poriyaan.in
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                               74
                                               www.Poriyaan.in
                    appropriate bucket
         Updates in Extendable Hash Structure
             To insert a record with search-key value Kj
                    – follow same procedure as look-up and locate the bucket, say j.
                    – If there is room in the bucket j insert record in the bucket.
                    – Overflow buckets used instead in some cases.
             To delete a key value,
                    – locate it in its bucket and remove it.
                    – The bucket itself can be removed if it becomes empty
                    – Coalescing of buckets can be done
                    – Decreasing bucket address table size is also possible
             Benefits of extendable hashing:
                    – Hash performance does not degrade with growth of file
                    – Minimal space overhead
             Disadvantages of extendable hashing
                    – Extra level of indirection to find desired record
         Bucket address table may itself become very big.
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                          75
                                                  www.Poriyaan.in
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                                   76
                                                www.Poriyaan.in
                  – (OP3):σDNO=5 (EMPLOYEE)
                  – (OP4):σ DNO=5 AND SALARY>30000 AND SEX = ‘F’ (EMPLOYEE)
                  – (OP5):σESSN=‘123456789’ AND PNO=10 (WORKS_ON)
               Many search methods can be used for simple selection: S1 through S6
               S1: Linear Search (brute force) –full scan in Oracle’s terminology-
                  – Retrieves every record in the file, and test whether its attribute values satisfy the selection condition:
                       an expensive approach.
                  – Cost: b/2 if key and b if no key
               S2: Binary Search
                  – If the selection condition involves an equality comparison on a key attribute on which the file is
                       ordered.
                  – σSSN=‘1234567’ (EMPLOYEE), SSN is the ordering attribute.
                  – Cost: log2b if key.
               S3: Using a Primary Index (hash key)
                  – An equality comparison on a key attribute with a primary index (or hash key).
                  – This condition retrieves a single record (at most).
                  – Cost :primary index : bind/2 + 1(hash key: 1bucket if no collision).
               S4: Using a primary index to retrieve multiple records
                  – Comparison condition is >, >=, <, or <= on a key field with a primary index
                  – σDNUMBER >5(DEPARTMENT)
                  – Use the index to find the record satisfying the corresponding equality condition (DNUMBER=5), then
                       retrieve all subsequent records in the (ordered) file.
                  – For the condition (DNUMBER <5), retrieve all the preceding records.
                  – Method used for range queries too(i.e. queries to retrieve records in certain range)
                  – Cost: bind/2 + ?. ‘?’ could be known if the number of duplicates known.
               S5: Using a clustering index to retrieve multiple records
                  – If the selection condition involves an equality comparison on a non-key attribute
                       with a clustering index.
                  – σDNO=5(EMPLOYEE)
                  – Use the index to retrieve all the records satisfying the condition.
                  – Cost: log2bind + ?. ‘?’ could be known if the number of duplicates known.
               S6: Using a secondary (B+-tree) index on an equality comparison
                  – The method can be used to retrieve a single record if the indexing field is a key or to retrieve multiple
                       records if the indexing field is not a key.
                  – This can also be used for comparisons involving >, >=, <, or <=.
                  – Method used for range queries too.
                  – Cost to retrieve: a key= height + 1; a non key= height+1(extra-level)+?, comparison=(height-1)+?+?
               Many search methods can be used for complex selection which involve a Conjunctive Condition: S7 through
                as S9.
                  – Conjunctive condition: several simple conditions connected with the AND logical connective.
                  – (OP4): s DNO=5 AND SALARY>30000 AND SEX = ‘F’ (EMPLOYEE).
               S7:Conjunctive selection using an individual index.
                  – If an attribute involved in any single simple condition in the conjunctive condition has an access path
                       that permits the use of one of the Methods S2 to S6, use that condition to retrieve the records.
                  – Then check whether each retrieved record satisfies the remaining simple conditions in the conjunctive
                       condition
               S8:Conjunctive selection using a composite index:
                  – If two or more attributes are involved in equality conditions in the conjunctive condition and a
                       composite index (or hash structure) exists on the combined fields.
                  – Example: If an index has been created on the composite key (ESSN, PNO) of the WORKS_ON file,
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                              77
                                                 www.Poriyaan.in
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                                78
                                                 www.Poriyaan.in
            3. Using commutativity and associativity of binary operations, rearrange the leaf nodes of the tree
            4. Combine a CARTESIAN PRODUCT operation with a subsequent SELECT operation in the tree into a
               JOIN operation, if the condition represents a join condition
            5. Using the cascading of PROJECT and the commuting of PROJECT with other operations, break down and
               move lists of projection attributes down the tree as far as possible by creating new PROJECT operations as
               needed
            6. Identify sub-trees that represent groups of operations that can be executed by a single algorithm
         Example
             Query
               "Find the last names of employees born after 1957 who work on a project named ‘Aquarius’."
             SQL
         SELECT LNAME
         FROM EMPLOYEE, WORKS_ON, PROJECT
         WHERE PNAME=‘Aquarius’ AND PNUMBER=PNO AND ESSN=SSN AND BDATE.‘1957-12-31’;
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                               79
                                                 www.Poriyaan.in
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                            80
                                                www.Poriyaan.in
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                              81
                                               www.Poriyaan.in
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                         82
                                                 www.Poriyaan.in
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                          83
                                                  www.Poriyaan.in
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                                84
                                                  www.Poriyaan.in
         Data Replication
                 If relation r is replicated, a copy of relation r is stored in two or more sites. In the most extreme case, we
         have full replication, in which a copy is stored in every site in the system.
         There are a number of advantages and disadvantages to replication.
         Availability If one of the sites containing relation r fails, then the relation r can be found in another site. Thus, the
         system can continue to process queries involving r, despite the failure of one site.
         Increased parallelism. In the case where the majority of accesses to the relation r result in only the reading of the
         relation, then several sites can process queries involving r in parallel. The more replicas of r there are, the greater
         the chance that the needed data will be found in the site where the transaction is executing. Hence, data replication
         minimizes movement of data between sites. Increased overhead on update. The system must ensure that all
         replicas of a relation r are consistent; otherwise, erroneous computations may result. Thus, whenever is updated, the
         update must be propagated to all sites containing replicas. The result is increased overhead. For example, in a
         banking system, where account information is replicated in various sites, it is necessary to ensure that the balance in
         a particular account agrees in all sites.
         Data Fragmentation
                 If relation r is fragmented, r is divided into a number of fragments r1, r2,...,rn. These fragments contain
         sufficient information to allow reconstruction of the original relation r.
                 There are two different schemes for fragmenting a relation: horizontal fragmentation and vertical
         fragmentation.
               Horizontal fragmentation splits the relation by assigning each tuple of r to one or more fragments.
               Vertical fragmentation splits the relation by decomposing the scheme R of relation r.
                 In horizontal fragmentation, a relation r is partitioned into a number of subsets, r1, r2,...,rn. Each tuple of
         relation r must belong to at least one of the fragments, so that the original relation can be reconstructed, if needed.
                      account1 = branch name = “Hillside” (account)
                      account2 = branch name = “Valleyview” (account)
         Horizontal fragmentation is usually used to keep tuples at the sites where they are used the most, to minimize data
         transfer.
                 In general, a horizontal fragment can be defined as a selection on the global relation r. That is, we use a
         predicate Pi to construct fragment ri:
         We reconstruct the relation r by taking the union of all fragments; that is:
                                                          r = r1 ∪ r2 ∪···∪ rn
         Transparency
                 The user of a distributed database system should not be required to know where the data are physically
         located nor how the data can be accessed at the specific local site. This characteristic, called data transparency,
         can take several forms:
         Fragmentation transparency. Users are not required to know how a relation has been fragmented.
         Replication transparency. Users view each data object as logically unique. The distributed system may replicate
         an object to increase either system performance or data availability. Users do not have to be concerned with what
         data objects have been replicated, or where replicas have been placed.
         Location transparency. Users are not required to know the physical location of the data. The distributed database
         system should be able to find any data as long as the data identifier is supplied by the user transaction.
          DISTRIBUTED TRANSACTIONS
          There are two types of transaction that we need to consider.
               Local transactions are those that access and update data in only one local database;
               Global transactions are those that access and update data in several local databases.
         System Structure
                  Each site has its own local transaction manager, whose function is to ensure the ACID properties of those
         transactions that execute at that site. The various transaction managers cooperate to execute global transactions. To
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                                  85
                                                  www.Poriyaan.in
         understand how such a manager can be implemented, consider an abstract model of a transaction system, in which
         each site contains two subsystems:
              The transaction manager manages the execution of those transactions (or sub transactions) that access data
                  stored in a local site.
              The transaction coordinator coordinates the execution of the various transactions (both local and global)
                  initiated at that site.
          Each transaction manager is responsible for:
               Maintaining a log for recovery purposes.
               Participating in an appropriate concurrency-control scheme to coordinate the concurrent execution of the
                   transactions executing at that site.
                  The transaction coordinator subsystem is not needed in the centralized environment, since a transaction
         accesses data at only a single site. A transaction coordinator, as its name implies, is responsible for coordinating the
         execution of all the transactions initiated at that site. For each such transaction, the coordinator is responsible for:
         • Starting the execution of the transaction.
         • Breaking the transaction into a number of sub transactions and distributing these sub transactions to the
         appropriate sites for execution.
         • Coordinating the termination of the transaction, which may result in the transaction being committed at all sites or
         aborted at all sites.
         System Failure Modes
               Failure of a site.
               Loss of messages.
               Failure of a communication link.
               Network partition.
         OBJECT-BASED DATABASES
                  An object-oriented database system is a database system that natively supports an object-oriented type
         system, and allows direct access to data from an object-oriented programming language using the native type
         system of the language.
         Complex Data Types
                  Traditional database applications have conceptually simple datatypes. The basic data items are records that
         are fairly small and whose fields are atomic.
                  In recent years, demand has grown for ways to deal with more complex data types. Consider, for example,
         addresses. While an entire address could be viewed as an atomic data item of type string, this view would hide
         details such as the street address, city, state, and postal code, which could be of interest to queries. On the other
         hand, if an address were represented by breaking it into the components (street address, city, state, and postal code),
         writing queries would be more complicated since they would have to mention each field. A better alternative is to
         allow structured datatypes that allow a type address with subparts street address, city, state, and postal code.
         Structured Types
                  Structured types allow composite attributes of E-R designs to be represented directly. For instance, we can
         define the following structured type to represent a composite attribute name with component attribute firstname and
         lastname:
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                                 86
                                                  www.Poriyaan.in
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                                87
                                                    www.Poriyaan.in
                  Suppose we wish to record information about books, including a set of keywords for each book. Suppose
         also that we wished to store the names of authors of a book as an array; unlike elements in a multiset, the elements
         of an array are ordered, so we can distinguish the first author from the second author, and so on. The following
         example illustrates how these array and multiset-valued attributes can be defined in SQL:
                                       create type Publisher as
                                       (name varchar(20),
                                       branch varchar(20));
                                       create type Book as
                                       (title varchar(20),
                                       Autho_arrray varchar(20) array [10],
                                       Pub_date date, publisher Publisher, keyword_set varchar(20) multiset);
                                       create table books of Book;
                  The first statement defines a type called Publisher with two components: a name and a branch. The second
         statement defines a structured type Book that contains a title, an author array, which is an array of up to 10 author
         names, a publication date, a publisher (of type Publisher), and a multiset of keywords. Finally, a table books
         containing tuples of type Book is created.
         Object-Identity and Reference Types in SQL
                  Object-oriented languages provide the ability to refer to objects. An attribute of a type can be a reference to
         an object of a specified type. For example, in SQL we can define a type Department with a field name and a field
         head that is a reference to the type Person, and a table departments of type Department, as follows:
                                               create type Department (
                                                name varchar(20),
                                               head ref(Person) scope people);
                                               create table departments of Department;
                  Here, the reference is restricted to tuples of the table people. The restriction of the scope of a reference to
         tuples of a table is mandatory in SQL, and it makes references behave like foreign keys.
         Object-relational Features
                  Object-relational database systems are basically extensions of existing relational database systems. Changes
         are clearly required at many levels of the database system. However, to minimize changes to the storage-system
         code (relation storage, indices, etc.), the complex datatypes supported by object-relational systems can be translated
         to the simpler type system of relational databases.
                  Sub tables can be stored in an efficient manner, without replication of all inherited fields, in one of two
         ways:
               Each table stores the primary key (which may be inherited from a parent table) and the attributes that are
                  defined locally. Inherited attributes (other than the primary key) do not need to be stored, and can be derived
                  by means of a join with the super table, based on the primary key.
               Each table stores all inherited and locally defined attributes. When a tuple is inserted, it is stored only in the
                  table in which it is inserted, and its presence is inferred in each of the super tables. Access to all attributes of
                  a tuple is faster, since a join is not required.
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                                      88
                                                   www.Poriyaan.in
         An object has five aspects: identifier, name, lifetime, structure, and creation.
              1. The object identifier is a unique system-wide identifier (or Object_id). Every object must have an object
                  identifier.
              2. Some objects may optionally be given a unique name within a particular ODMS—this name can be used to
                  locate the object, and the system should return the object given that name. Obviously, not all individual
                  objects will have unique names. Typically, a few objects, mainly those that hold collections of objects of a
                  particular object type—such as extents—will have a name. These names are used as entry points to the
                  database; that is, by locating these objects by their unique name, the user can then locate other objects that
                  are referenced from these objects. Other important objects in the application may also have unique names,
                  and it is possible to give more than one name to an object. All names within a particular ODMS must be
                  unique.
              3. The lifetime of an object specifies whether it is a persistent object (that is, a database object) or transient
                  object (that is, an object in an executing pro-gram that disappears after the program terminates). Lifetimes
                  are independent of types—that is, some objects of a particular type may be transient whereas others may be
                  persistent.
              4. The structure of an object specifies how the object is constructed by using the type constructors. The
                  structure specifies whether an object is atomic or not. An atomic object refers to a single object that follows
                  a user-defined type, such as Employee or Department. If an object is not atomic, then it will be composed of
                  other objects. For example, a collection object is not an atomic object, since its state will be a collection of
                  other objects. In the ODMG model, an atomic object is any individual user-defined object. All values of the
                  basic built-in data types are considered to be literals.
              5. Object creation refers to the manner in which an object can be created. This is typically accomplished via
                  an operation new for a special Object_Factory interface.
                  In the object model, a literal is a value that does not have an object identifier. However, the value may have
         a simple or complex structure.
         There are three types of literals: atomic, structured, and collection.
              1. Atomic literals correspond to the values of basic data types and are predefined. The basic data types of the
                  object model include long, short, and unsigned integer numbers (these are specified by the
                  keywords long, short, unsigned long, and unsigned short in ODL), regular and double precision floating
                  point numbers (float, double), Boolean values (boolean), single characters (char), character strings (string),
                  and enumeration types (enum), among others.
              2. Structured literals correspond roughly to values that are constructed using the tuple constructor. The built-in
                  structured lit-erals include Date, Interval,Time, and Timestamp.
              3. Collection literals specify a literal value that is a collection of objects or values but the collection itself does
                  not have an Object_id. The collections in the object model can be defined by the type
                  generators set<T>, bag<T>, list<T>, and array<T>, where T is the type of objects or values in the
                  collection.28 Another collection type is dictionary<K, V>, which is a collection of associations <K, V>,
                  where each K is a key (a unique search value) associated with a value V; this can be used to create an index
                  on a collection of values V.
                  The notation of ODMG uses three concepts: interface, literal, and class. Following the ODMG
         terminology, we use the word behavior to refer to operations and state to refer to properties (attributes and
         relationships).
                  An interface specifies only behavior of an object type and is typically noninstantiable (that is, no objects
         are created corresponding to an interface). Although an interface may have state properties (attributes and
         relationships) as part of its specifications, these cannot be inherited from the interface. Hence, an interface serves to
         define operations that can be inherited by other interfaces, as well as by classes that define the user-defined objects
         for a particular application.
                  A class specifies both state (attributes) and behavior (operations) of an object type, and is instantiable.
         Hence, database and application objects are typically created based on the user-specified class declarations that form
         a database schema.
                  Finally, a literal declaration specifies state but no behavior. Thus, a literal instance holds a simple or
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                                     89
                                                  www.Poriyaan.in
         complex structured value but has neither an object identifier nor encapsulated operations.
         ODL: OBJECT DEFINITION LANGUAGE
                 Object Definition Language (ODL) is the specification language defining the interface to object types
         conforming to the ODMG Object Model. Often abbreviated by the acronym ODL.This language's purpose is to
         define the structure of an Entity-relationship diagram.
         Class Declarations
               interface < name > {elements = attributes, relationships, methods }
         Element Declarations
               attribute < type > < name > ;
               relationship < rangetype > < name > ;
         Method Example
              float gpa(in: Student) raises(noGrades) float = return type.
              in: indicates Student argument is read-only.
                 Other options: out, inout.
         Relationships
              use inverse to specify inverse relationships 
              at most one' semantics remain
              multiplicity
                     o if many-many between C and D, then use Set<D> and Set<C>, respectively
                     o if many-one from C to D, then use D in C and Set<C> in D
                     o if many-one from D to C, then use C in D and Set<D> in C
                     o if one-one between C and D, then use D and C, respectively
         Datatypes
              basis
                     o atomic: integer, float, character, character string, boolean, and enumeration
                     o classes
              type constructors (can be composed to create complex types)
                     o set: Set<T>
                     o bag: Bag<T>
                     o list: List<T> (sequential access)
                     o array: Array<T,i> (random access)
                     o dictionary: Dictionary<T,S>
                     o structures
              difference between sets, bags, and lists
              rules for types and relationships
                     o type of a relationship is either a class type or a (single use of a) collection type constructor applied
                         to a class type' [FCDB]
                     o type of an attribute is built starting with atomic type(s)' [FCDB]
              relationship types cannot involve
                     o atomic types (e.g., Set<integer>),
                     o structures (e.g., Struct N {Movie field1, Star field2}, or
                     o two applications of collection types (e.g., Set<Array<Star, 10>>)
         Similarities between E/R and ODL
              both support all multiplicities of relationships 
              both support inheritance
         Differences between E/R and ODL
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                               90
                                                   www.Poriyaan.in
Banking Example 1
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                               91
                                                 www.Poriyaan.in
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                                92
                                                www.Poriyaan.in
         slash.</…..>.
                  Complex elements are constructed from other elements hierarchically, whereas simple elements contain
         data values. A major difference between XML and HTML is that XML tag names are defined to describe the
         meaning of the data elements in the document, rather than to describe how the text is to be displayed. This makes it
         possible to process the data elements in the XML document automatically by computer programs. Also, the XML
         tag (element) names can be defined in another document, known as the schema document, to give a semantic
         meaning to the tag names that can be exchanged among multiple users. In HTML, all tag names are predefined and
         fixed; that is why they are not extendible.
         It is possible to characterize three main types of XML documents:
                Data-centric XML documents. These documents have many small data items that follow a specific
                  structure and hence may be extracted from a structured database. They are formatted as XML documents in
                  order to exchange them over or display them on the Web. These usually follow a predefined schema that
                  defines the tag names.
                Document-centric XML documents. These are documents with large amounts of text, such as news
                  articles or books. There are few or no structured data elements in these documents.
                Hybrid XML documents. These documents may have parts that contain structured data and other parts that
                  are predominantly textual or unstructured. They may or may not have a predefined schema.
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                             93
                                                 www.Poriyaan.in
                 XML documents that do not follow a predefined schema of element names and corresponding tree structure
         are known as schemaless XML documents. It is important to note that data-centric XML documents can be
         considered either as semistructured data or as structured data
          DOCUMENT TYPE DEFINITION (DTD)
                 The document type definition (DTD) is an optional part of an XML document. The main purpose of a DTD
         is much like that of a schema: to constrain and type the information present in the document.
                  However, the DTD does not in fact constrain types in the sense of basic types like integer or string. Instead,
         it constrains only the appearance of sub elements and attributes within an element. The DTD is primarily a list of
         rules for what pattern of subelements may appear within an element.
         Example of a DTD
                  Thus, in the DTD, a university element consists of one or more course, department, or instructor elements;
         the operator specifies “or” while the + operator specifies “one or more.” Although not shown here, the ∗ operator is
         used to specify “zero or more,” while the? operator is used to specify an optional element (that is, “zero or one”).
         The course element contains sub elements course id, title, dept name, and credits (in that order).
                  Similarly, department and instructor have the attributes of their relational schema defined as sub elements in
         the DTD. Finally, the elements course id, title, dept name, credits, building, budget, IID, name, and salary are all
         declared to be of type #PCDATA. The keyword #PCDATA indicates text data; it derives its name, historically, from
         “parsed character data.” Two other special type declarations are empty, which says that the element has no contents,
         and any, which says that there is no constraint on the sub elements of the element; that is, any elements, even those
         not mentioned in the DTD, can occur as sub elements of the element. The absence of a declaration foran element is
         equivalent to explicitly declaring the type as any.
         XML SCHEMA
                  XML Schema defines a number of built-in types such as string, integer, decimal date, and boolean. In
         addition, it allows user-defined types; these may be simple types with added restrictions, or complex types
         constructed using constructors such as complex Type and sequence.
                  Note that any namespace prefix could be used in place of xs; thus we could replace all occurrences of “xs:”
         in the schema definition with “xsd:” without changing the meaning of the schema definition. All types defined by
         XML Schema must be prefixed by this namespace prefix. The first element is the root element university, whose
         type is specified to be University Type, which is declared later. The example then defines the types of elements
         department, course, instructor, and teaches. Note that each of these is specified by an element with tag xs:element,
         whose body contains the type definition.
         The type of department is defined to be a complex type, which is further specified to consist of a sequence of
         elements dept name, building, and budget.           Any type that has either attributes or nested sub elements must be
         specified to be a complex type. Alternatively, the type of an element can be specified to be a predefined type by the
         attribute type; observe how the XML Schema types xs: string and xs: decimal are used to constrain the types of data
         elements such as dept name and credits. Finally, the example defines the type University Type as containing zero or
         more occurrences of each of department, course, instructor, and teaches. Note the use of ref to specify the occurrence
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                                94
                                            www.Poriyaan.in
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                 95
                                                 www.Poriyaan.in
                  Attributes are specified using the xs:attribute tag. For example, we could have defined dept name as an
         attribute by adding:
         <xs:attribute name = “dept name”/>
         within the declaration of the department element. Adding the attribute use = “required” to the above attribute
         specification declares that the attribute must be specified, whereas the default value of use is optional. Attribute
         specifications would appear directly under the enclosing complex Type specification, even if elements are nested
         within a sequence specification.
                  In addition to defining types, a relational schema also allows the specification of constraints. XML Schema
         allows the specification of keys and key references, corresponding to the primary-key and foreign-key definition in
         SQL. In SQL, a primary-key constraint or unique constraint ensures that the attribute values do not recur within the
         relation. In the context of XML, we need to specify a scope within which values are unique and form a key. The
         selector is a path expression that defines the scope for the constraint, and field declarations specify the elements or
         attributes that form the key. To specify that dept name forms a key for department elements under the root university
         element, we add the following constraint specification to the schema definition:
         XML Schema offers several benefits over DTDs, and is widely used today. Among the benefits that we have seen in
         the examples above are these:
              It allows the text that appears in elements to be constrained to specific types, such as numeric types in
                  specific formats or complex types such as sequences of elements of other types.
              It allows user-defined types to be created.
              It allows uniqueness and foreign-key constraints.
              It is integrated with namespaces to allow different parts of a document to conform to different schemas.
         In addition to the features we have seen, XML Schema supports several other features that DTDs do not, such as
         these:
              It allows types to be restricted to create specialized types, for instance by specifying minimum and
                  maximum values.
              It allows complex types to be extended by using a form of inheritance.
         XQUERY
                  XPath allows us to write expressions that select items from a tree-structured XML document. XQuery
         permits the specification of more general queries on one or more XML documents. The typical form of a query in
         XQuery is known as a FLWR expression, which stands for the four main clauses of XQuery and has the following
         form:
                         FOR<variable bindings to individual nodes (elements)>
                         LET <variable bindings to collections of nodes (elements)>
                         WHERE <qualifier conditions>
                         RETURN<query result specification>
                  There can be zero or more instances of the FOR clause, as well as of the LET clause in a single XQuery. The
         WHERE clause is optional, but can appear at most once, and the RETURN clause must appear exactly once. Let us
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                              96
                                                  www.Poriyaan.in
             1. Variables are prefixed with the $ sign. In the above example, $d, $x, and $y are variables.
             2. The LET clause assigns a variable to a particular expression for the rest of the query. In this example, $d is
                  assigned to the document file name. It is possible to have a query that refers to multiple documents by
                  assigning multiple variables in this way.
             3. The FOR clause assigns a variable to range over each of the individual items in a sequence. In our example,
                  the sequences are specified by path expressions. The $x variable ranges over elements that satisfy the path
                  expression $d/company/project[projectNumber = 5]/projectWorker. The $y variable ranges over elements
                  that satisfy the path expression $d/company/employee. Hence, $x ranges over projectWorker elements,
                  whereas $y ranges over employee elements.
             4. The WHERE clause specifies additional conditions on the selection of items. In this example, the first
                  condition selects only those projectWorker elements that satisfy the condition (hours gt 20.0). The second
                  condition specifies a join condition that combines an employee with a projectWorker only if they have the
                  same ssn value.
             5. Finally, the RETURN clause specifies which elements or attributes should be retrieved from the items that
                  satisfy the query conditions. In this example, it will return a sequence of elements each containing for
                  employees who work more that 20 hours per week on project number 5.
                  XQuery has very powerful constructs to specify complex queries. In particular, it can specify universal and
         existential quantifiers in the conditions of a query, aggregate functions, ordering of query results, selection based on
         position in a sequence, and even conditional branching. Hence, in some ways, it qualifies as a full-fledged
         programming language.
         INFORMATION RETRIEVAL
         IR CONCEPTS
                  Information retrieval is the process of retrieving documents from a collection in response to a query (or a
         search request) by a user. Information retrieval is “the discipline that deals with the structure, analysis, organization,
         storage, searching, and retrieval of information” as defined by Gerald Salton, an IR pioneer.
                  Information in the context of IR does not require machine-understandable structures, such as in relational
         database systems. Examples of such information include written texts, abstracts, documents, books, Web pages, e-
         mails, instant messages, and collections from digital libraries. Therefore, all loosely represented (unstructured) or
         semi structured information is also part of the IR discipline.
                  IR systems go beyond database systems in that they do not limit the user to a specific query language, nor do
         they expect the user to know the structure (schema) or content of a particular database. IR systems use a user’s
         information need expressed as a free-form search request (sometimes called a keyword search query, or just
         query) for interpretation by the system.
                  An IR system can be characterized at different levels: by types of users, types of data, and the types of the
         information need, along with the size and scale of the information repository it addresses. Different IR systems are
         designed to address specific problems that require a combination of different characteristics. These characteristics
         can be briefly described as follows:
         Types of Users
                  The user may be an expert user (for example, a curator or a librarian), who is searching for specific
         information that is clear in his/her mind and forms relevant queries for the task, or a layperson user with a generic
         information need.
         Types of Data
                  Search systems can be tailored to specific types of data. For example, the problem of retrieving information
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                                   97
                                                 www.Poriyaan.in
         about a specific topic may be handled more efficiently by customized search systems that are built to collect and
         retrieve only information related to that specific topic. The information repository could be hierarchically organized
         based on a concept or topic hierarchy. These topical domain-specific or vertical IR systems are not as large as or as
         diverse as the generic World Wide Web, which contains information on all kinds of topics.
         Types of Information Need
                  In the context of Web search, users’ information needs may be defined as navigational, informational, or
         transactional.
                  Navigational search refers to finding a particular piece of information (such as the Georgia Tech University
         Website) that a user needs quickly. The purpose of informational search is to find current information about a topic
         (such as research activities in the college of computing at Georgia Tech—this is the classic IR system task). The goal
         of transactional search is to reach a site where further interaction happens (such as joining a social network,
         product shopping, online reservations, accessing databases, and so on).
         RETRIEVAL MODELS
                  There are the three main statistical models—Boolean, vector space, and probabilistic—and the semantic
         model.
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                               98
                                                 www.Poriyaan.in
         relevant to an IR search for this particular set of documents. The process of selecting these important terms
         (features) and their properties as a sparse (limited) list out of the very large number of available terms (the
         vocabulary can contain hundreds of thousands of terms) is independent of the model specification. The query is also
         specified as a terms vector (vector of features), and this is compared to the document vectors for similarity/relevance
         assessment.
                  In the vector model, the document term weight wij (for term i in document j) is represented based on some
         variation of the TF (term frequency) or TF-IDF (term frequency-inverse document frequency) scheme (as we will
         describe below). TF-IDF is a statistical weight measure that is used to evaluate the importance of a document word
         in a collection of documents. The following formula is typically used:
         Probabilistic Model
                 In the probabilistic framework, the IR system has to decide whether the documents belong to the relevant
         set or the nonrelevant set for a query. To make this decision, it is assumed that a predefined relevant set and
         nonrelevant set exist for the query, and the task is to calculate the probability that the document belongs to the
         relevant set and compare that with the probability that the document belongs to the nonrelevant set.
                 Given the document representation D of a document, estimating the relevance R and nonrelevance NR of
         that document involves computation of conditional probability P(R|D) and P(NR|D). These conditional probabilities
         can be calculated using Bayes’ Rule
                                            P(R|D) = P(D|R) × P(R)/P(D)
                                            P(NR|D) = P(D|NR) × P(NR)/P(D)
                 A document D is classified as relevant if P(R|D) > P(NR|D). Discarding the constant P(D), this is equivalent
         to saying that a document is relevant if:
                                            P(D|R) × P(R) > P(D|NR) × P(NR)
                 The likelihood ratio P(D|R)/P(D|NR) is used as a score to determine the likelihood of thedocument with
         representation D belonging to the relevant set.
         Semantic Model
                 Semantic approaches include different levels of analysis, such as morphological, syntactic, and semantic
         analysis, to retrieve documents more effectively. In morphological analysis, roots and affixes are analyzed to
         determine the parts of speech (nouns, verbs, adjectives, and so on) of the words.
                 The development of a sophisticated semantic system requires complex knowledge bases of semantic
         information as well as retrieval heuristics. These systems often require techniques from artificial intelligence and
         expert systems. Knowledge bases like Cyc15 and WordNet16 have been developed for use in knowledge-based IR
         systems based on semantic models.
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                                99
                                                 www.Poriyaan.in
         QUERIES IN IR SYSTEMS
                  The queries formulated by users are compared to the set of index keywords. Most IR systems also allow the
         use of Boolean and other operators to build a complex query. The query language with these operators enriches the
         expressiveness of a user’s information need.
         Keyword Queries
                  Keyword-based queries are the simplest and most commonly used forms of IR queries: the user just enters
         keyword combinations to retrieve documents. The query keyword terms are implicitly connected by a logical AND
         operator. A query such as ‘database concepts’ retrieves documents that contain both the words ‘database’ and
         ‘concepts’ at the top of the retrieved results. In addition, most systems also retrieve documents that contain only
         ‘database’ or only ‘concepts’ in their text. Some systems remove most commonly occurring words (such as a, the,
         of, and so on, called stop words) as a preprocessing step before sending the filtered query keywords to the IR engine.
         Boolean Queries
                  Some IR systems allow using the AND, OR, NOT, ( ), + , and – Boolean operators in combinations of
         keyword formulations. AND requires that both terms be found. OR lets either term be found. NOT means any record
         containing the second term will be excluded. ‘( )’ means the Boolean operators can be nested using parentheses. ‘+’
         is equivalent to AND, requiring the term; the ‘+’ should be placed directly in front of the search term.‘–’ is
         equivalent to AND NOT and means to exclude the term; the ‘–’ should be placed directly in front of the search term
         not wanted. Complex Boolean queries can be built out of these operators and their combinations, and they are
         evaluated according to the classical rules of Boolean algebra.
         Phrase Queries
                  When documents are represented using an inverted keyword index for searching, the relative order of the
         terms in the document is lost. In order to perform exact phrase retrieval, these phrases should be encoded in the
         inverted index or implemented differently (with relative positions of word occurrences in documents). A phrase
         query consists of a sequence of words that makes up a phrase. The phrase is generally enclosed within double
         quotes. Each retrieved document must contain at least one instance of the exact phrase. Phrase searching is a more
         restricted and specific version of proximity searching.
         Proximity Queries
                  Proximity search refers to a search that accounts for how close within a record multiple terms should be to
         each other. The most commonly used proximity search option is a phrase search that requires terms to be in the exact
         order.
         Wildcard Queries
                  Wildcard searching is generally meant to support regular expressions and pattern matching-based searching
         in text. In IR systems, certain kinds of wildcard search support may be implemented—usually words with any
         trailing characters (for example, ‘data*’ would retrieve data, database, datapoint, dataset, and so on).
         Natural Language Queries
                  There are a few natural language search engines that aim to understand the structure and meaning of queries
         written in natural language text, generally as a question or narrative. This is an active area of research that employs
         techniques like shallow semantic parsing of text, or query reformulations based on natural language understanding.
         The system tries to formulate answers for such queries from retrieved results. Some search systems are starting to
         provide natural language interfaces to provide answers to specific types of questions, such as definition and factoid
         questions, which ask for definitions of technical terms or common facts that can be retrieved from specialized
         databases.
https://play.google.com/store/apps/details?id=com.poriyaan.poriyaan                                                                100
                              Database Management System
                                      Physics
                                    Basic     for Engineering
                                          Electrical and                   Data Structure
  Problem Solving and                 Science Engineering
                                  Electronics
  Python Programming                                                      Object Oriented
                                    Programming in C
                                                                           Programming
Elective-Management
Professional Elective II
Professional Elective IV