Advanced Database System
Chapter-1
Object Oriented Database System
Outline
Overview of Object Oriented Concepts
Type and Class Hierarchies and Inheritance
Object Oriented Databases
Object Identity and Type Constructors
Object Persistence
Complex Objects
Overview of Object-Oriented Concepts
Object-oriented(OO ) is originating from OO
programming languages( OOPLs).
OO concepts are important for the areas of:
Databases
Software engineering
Knowledge bases systems
Artificial intelligence and
Computer systems.
Example: C++ and java programming language.
Cont.…
What is Object?
A uniquely identifiable entity that contains both the attributes
that describe the state of a ‘real world’ object and the actions that
are associated with it.
It has two components:
State (value) and
Behavior (operations).
It can have a complex data structure as well as specific operations
defined by the programmer.
Cont.…
Types of objects:
There are two types of objects in OODBS
Transient objects
Persistent objects
Transient objects:
Objects that exist only during program execution
Persistent objects:
objects that are stored permanently in a database
objects that exist beyond program termination and can be retrieved later and shared by
Cont.…
Internal Structure of Object
The internal structure of an object in OOPLs includes the specification of instance variables.
Instance variables:
It hold the values that define the internal state of the object.
It is similar to the concept of an attribute in the relational model, except that instance variables
may be encapsulated within the object and are not necessarily visible to external users.
It may also be of subjectively complex data types.
Object-oriented systems allow definition of the operations or functions (behavior) that can be
applied to objects of a particular type.
Cont.…
Abstract Data Types: class definition that provides extension to
complex attribute types.
Encapsulation: is the implementation of operations and object
structure making hidden.
Inheritance: sharing of data within hierarchy scope and supports
code reusability.
Polymorphism: Operations and method names can be overloaded to
apply to different object types with different implementations.
Cont.…
Encapsulation
Some OO models maintain all operations that a user can apply to an object must be predefined. This forces a complete
encapsulation of objects.
To encourage encapsulation, an operation is defined in two parts:
signature or interface of the operation, specifies the operation name and arguments (or parameters).
method or body, specifies the implementation of the operation.
Operations can be invoked by passing a message to an object, which includes the operation name and the parameters.
Encapsulation in the relational model the operations for selecting, inserting, deleting, and modifying tuples are generic and
may be applied to any relation in the database. The relation and its attributes are visible to users and to external programs that
access the relation by using these operations.
The concept of encapsulation in ODBs is by defining the behavior of a type of object based on the operations that can be
externally applied to objects of that type.
Cont..
Operator polymorphism:
It refers to an operation’s ability to be applied to different types of objects; in such a situation,
an operation name may refer to several distinct implementations, depending on the type of
objects it is applied to.
It is also called operator overloading
allows the same operator name or symbol to be bound to two or more different
implementations of the operator, depending on the type of objects to which the operator is
applied.
For example + can be:
Addition in integers
Concatenation in strings (of characters)
Type, class hierarchies and inheritance
A type is defined by assigning it a type name and then defining a number of
attributes (instance variables) and operations (methods) for the type.
TYPE_NAME: function, function, … , function
Functions are attributes and operations.
Example: PERSON: Name, Address, Birth_date, Age, Ssn
Inheritance allows the definition of new types based on other predefined types,
leading to a type (or class) hierarchy. It makes it easier to develop the data types of
a system incrementally and to reuse existing type definitions when creating new
types of objects.
OO Databases
Database systems that were based on the object data model were known originally as object-oriented databases
(OODBs) but are now referred to as object databases (ODBs).
OO databases store persistent objects permanently in secondary storage and allow the sharing of these objects
among multiple programs and applications.
OO databases requires the incorporation of other well-known features of database management systems. such as
Indexing mechanisms to efficiently locate the objects,
Concurrency control to allow object sharing among concurrent programs, and
Recovery from failures.
An OO database system will typically interface with one or more OO programming languages to provide
persistent and shared object capabilities.
Why Object Oriented Databases?
Reasons for the need or creation of Object Oriented Databases:
Need for more complex applications
Need for additional data modeling features
Increased use of object-oriented programming languages
Limitation of RDBMS( like Poor representation of real world entities, limited
operations, homogeneous data structure, ….)
Characteristics of object databases
Some of the detail of the main characteristics/ features of object databases are:
OODBs provide system generated object identifier for each object
It keeps up a direct relation between real world and database objects as if objects do not loose
their integrity and identity.
OODBs are extensible, which identifies new data types and the operations to be performed on
them.
Provides encapsulation, feature which, the data representation and the methods implementation
are hidden from external entities.
Also provides inheritance properties in which an object inherits the properties of other objects.
Object Identity (OID )
A unique identity is assigned to each independent object stored in the database.
It is typically implemented via a unique, system-generated object identifier (OID).
The value of an OID may not be visible to the external user but is used internally
by the system to identify each object uniquely and to create and manage inter object
references.
The OID can be assigned to program variables of the appropriate type when needed.
The main property required of an OID is that it be immutable;
The OID value of a particular object in ODB should not change.
This preserves the identity of the real-world object being represented.
Object Database Management system(ODMS)
ODMS must have some mechanism for generating OIDs and preserving the
immutability property.
OID is also desirable that each OID be used only once;
Even if an object is removed from the database, its OID should not be
assigned to another object.
The two properties of OID imply that the OID should not depend on any attribute
values of the object, since the value of an attribute may be changed or corrected.
Objects and literals
Objects and Literals are the basic building blocks of the object model
Objects
has both an object identifier and a state (or current value)
The object state can change over time by modifying the object value
Literals
has a value (state) but no object identifier
It is basically a constant value, possibly having a complex structure, but it
does not change.
Type Constructors
In OO databases, the state (current value) of a complex object may be
constructed from other objects (or other values) by using certain type
constructors.
The three most basic type constructors
Atom constructors
Tuple constructors
Set constructors
Other commonly used constructors include list, bag, and array.
Cont.…
Atom constructor:
It is used to represent all basic atomic values or built-in data types of the object model
such as integers, strings, floating-point numbers, enumerated types, Booleans, and so on.
These basic data types are called single valued or atomic types, it is considered an atomic (indivisible)
single value.
Struct (or tuple) constructor:
This can create standard structured types, such as the tuples (record types) in the basic relational model.
A structured type is made up of several components and sometimes referred to as a compound or
composite type.
More accurately, struct constructor is not considered to be a type, but rather a type generator, because
many different structured types can be created.
Cont.…
For example, two different structured types that can be created are:
struct Name<FirstName: string, MiddleInitial: char, LastName: string>, and
struct CollegeDegree<Major: string, Degree: string, Year: date>.
To create complex nested type structures in the object model, the collection type constructors are
needed.
Notice that: the type constructors’ atom and struct are the only ones available in the original (basic)
relational model.
The tuple constructor can create structured values and objects of the form <a1:i1, a2:i2… an:in>,
where each aj is an attribute name and each ij is a value or an OID.
Cont.…
Collection (or multivalued) type constructors
It includes the set(T), list(T), bag(T), array(T), and dictionary(K,T) type constructors.
These allow part of an object or literal value to include a collection of other objects or values when
needed.
They are also considered to be type generators because many different types can be created.
set(string), set(integer), and set(Employee)
All the elements in a particular collection value must be of the same type.
For example, all values in a collection of type set(string) must be string values.
Cont.…
The tuple constructor can create structured values and objects of the form
<a1:i1, a2:i2… an:in>, where each aj is an attribute name and each ij is a value
An object definition language (ODL) that incorporates the preceding type
constructors can be used to define the object types for a particular database
application.
The type constructors can be used to define the data structures for an OO
database schema.
Cont.…
Example 1
One possible relational database state corresponding to COMPANY schema
Cont.…
Cont.…
Cont.…
Identify atomic value, set value and tuple value objects?
We use i1, i2, i3, . . . to stand for unique system-generated object identifiers. Consider the following objects:
• o1 = (i1, atom, ‘Houston’)
• o2 = (i2, atom, ‘Bellaire’)
• o3 = (i3, atom, ‘Sugarland’)
• o4 = (i4, atom, 5)
• o5 = (i5, atom, ‘Research’)
• o6 = (i6, atom, ‘1988-05-22’)
• o7 = (i7, set, {i1, i2, i3})
• o8 = (i8, tuple, <dname:i5, dnumber:i4, mgr:i9, locations:i7, employees:i10, projects:i11>)
• o9 = (i9, tuple, <manager:i12, manager_start_date:i6>)
• o10 = (i10, set, {i12, i13, i14})
• o11 = (i11, set {i15, i16, i17})
• o12 = (i12, tuple, <fname:i18, minit:i19, lname:i20, ssn:i21, . . ., salary:i26, supervisor:i27, dept:i8>)
• ...
Cont.…
We use i1, i2, i3, . . . to stand for unique system-generated object identifiers. Consider the
following objects:
• o1 = (i1, atom, ‘Houston’)
• o2 = (i2, atom, ‘Bellaire’)
• o3 = (i3, atom, ‘Sugarland’) atomic values objects
• o4 = (i4, atom, 5)
• o5 = (i5, atom, ‘Research’)
• o6 = (i6, atom, ‘1988-05-22’)
• o7 = (i7, set, {i1, i2, i3}) set-valued object
• o8 = (i8, tuple, <dname:i5, dnumber:i4, mgr:i9, locations:i7, employees:i10, projects:i11>) ------tuple-valued
object
• o9 = (i9, tuple, <manager:i12, manager_start_date:i6>)
• o10 = (i10, set, {i12, i13, i14})
• o11 = (i11, set {i15, i16, i17})
Cont.…
The first six objects listed in this example represent atomic values objects.
Object seven is a set-valued object that represents the set of locations for department 5;
the set refers to the atomic objects with values {‘Houston’, ‘Bellaire’, ‘Sugarland’}.
Object 8 is a tuple-valued object that represents department 5 itself, and has the
attributes DNAME, DNUMBER, MGR, LOCATIONS, and so on.
Cont.…
Example 2:
This example illustrates the difference between the two definitions for comparing object states for equality.
o1 = (i1, tuple, <a1:i4, a2:i6>)
o2 = (i2, tuple, <a1:i5, a2:i6>)
o3 = (i3, tuple, <a1:i4, a2:i6>)
o4 = (i4, atom, 10)
o5 = (i5, atom, 10)
o6 = (i6, atom, 20)
In this example, the objects o1 and o2 have equal states, since their states at the atomic level are the same but
the values are reached through distinct objects o4 and o5.
However, the states of objects o1 and o3 are identical, even though the objects themselves are not because
they have distinct OIDs.
Similarly, although the states of o4 and o5 are identical, the actual objects o4 and o5 are equal but not
identical, because they have distinct OIDs.
Cont.….
Cont.…
How to declare EMPLOYEE and DEPARTMENT types?
Object Behavior
Specifying Object Behavior via Class Operations:
The main idea is to define the behavior of a type of object based on the operations
that can be externally applied to objects of that type.
In general, the implementation of an operation can be specified in a general-purpose
programming language that provides flexibility and power in defining the operations.
For database applications, the requirement that all objects be completely encapsulated
is too severe.
One way of relaxing this requirement is to divide the structure of an object into visible
and hidden attributes (instance variables).
Cont.…
Storage and Access of Persistent Objects
Specifying Object Persistence via Naming and Reachability:
An ODBS is often closely coupled with an object-oriented programming language (OOPL).
The OOPL is used to specify the method (operation) implementations as well as other application code.
Not all objects are meant to be stored permanently in the database.
The typical mechanisms for making an object persistent are naming and reachability.
Naming Mechanism:
o It involves giving an object a unique persistent name within a particular database.
o Assign an object a unique persistent name through which it can be retrieved by name and other programs.
Reachability Mechanism:
o Make the object reachable from some persistent object.
o An object B is said to be reachable from an object A if a sequence of references in the object graph lead from object A to
object B.
Cont.…
In traditional database models such as relational model or EER model, all
objects are assumed to be persistent.
In OO approach, a class declaration specifies only the type and operations for
a class of objects.
In OO approach, the user must separately define a persistent object of type
set (DepartmentSet) or list (DepartmentList) whose value is the collection of
references to all persistent DEPARTMENT objects.
Cont.…
Type Hierarchies and Inheritance
The inheritance model of the ODMG standard distinguishes between two types of inheritance.
Subtype inheritance
o It is useful when the designer or user must create a new type that is similar but not identical to an already defined type.
Supertype:
o It inherits all the functions of the subtype
Example (1):
• PERSON: Name, Address, Birthdate, Age, SSN
• EMPLOYEE: Name, Address, Birthdate, Age, SSN, Salary, HireDate, Seniority
• STUDENT: Name, Address, Birthdate, Age, SSN, Major, GPA
• OR:
• EMPLOYEE subtype-of PERSON: Salary, HireDate, Seniority
• STUDENT subtype-of PERSON: Major, GPA
Cont.…
Both STUDENT and EMPLOYEE include all the functions defined for PERSON + some additional
functions of their own, we can declare them to be subtypes of PERSON.
Each will inherit the previously defined functions of PERSON namely, Name, Address, Birth_date, Age, and
Ssn.
For STUDENT, it is only necessary to define the new (local) functions Major and Gpa, which are not
inherited.
Therefore, we can declare EMPLOYEE and STUDENT as follows:
Cont.….
In general, a subtype includes all of the functions that are defined for its supertype plus some
additional functions that are specific only to the subtype.
Hence, it is possible to generate a type hierarchy to show the supertype/ subtype relationships
among all the types declared in the system.
Multiple inheritance in a type hierarchy occurs when a certain subtype T is a subtype of two (or
more) types and hence inherits the functions (attributes and methods) of both supertypes.
For example, we may create a subtype ENGINEERING_MANAGER that is a subtype of
both MANAGER and ENGINEER.
Selective inheritance occurs when a subtype inherits only some of the functions of a supertype.
Cont.…
Constraints on Extents Corresponding to a Type Hierarchy
o an extent is defined to store the collection of persistent objects for each type or subtype. An extent is a named as
persistent object whose value is a persistent collection and transient objects whose value is transient collection.
Persistent Collection:
o It holds a collection of objects that is stored permanently in the database and hence can be accessed and shared
by multiple programs
Transient Collection:
o It exists temporarily during the execution of a program but is not kept when the program terminates.
Constraint
o every object in an extent that corresponds to a subtype must also be a member of the extent that
corresponds to its supertype.
Complex Objects
A complex object is an item that is viewed as a single object in the ‘real world’ but combines with other
objects in a set of complex A-PART-OF(AFO) relationships.
The objects contained may themselves be complex objects, resulting in an A-PART-OF hierarchy.
In an object oriented system, a contained object can be handled in one of two ways.
First, a contained object can be encapsulated within the complex object and form part of the complex
object.
In this case, the structure of the contained object is part of the structure of the complex object and can be
accessed only by the complex object’s methods.
Second, a contained object can be considered to have an independent existence from the complex object.
In this case, the object is not stored directly in the parent object but only its OID.
Cont.…
Types of complex object
Structured complex object
o the object’s structure is defined by repeated application of the type constructors provided by
the OODBMS.
o Hence, the object structure is defined and known to the OODBMS.
o The OODBMS also defines methods or operations on it.
Unstructured complex objects
o provided by a DBMS and permits the storage and retrieval of large objects that are needed by
the database application.
o Typical examples of such objects are bitmap images and long text strings (such as
documents); they are also known as binary large objects, or BLOBs for short.
Questions?