Professional Documents
Culture Documents
of
DBMS
Introduction
A computer database relies upon software to organize the storage of data. This software
is known as a database management system (DBMS). Database management systems
are categorized according to the database model that they support. The model tends to
determine the query languages that are available to access the database. A great deal of
the internal engineering of a DBMS, however, is independent of the data model, and is
concerned with managing factors such as performance, concurrency, integrity, and
recovery from hardware failures. In these areas there are large differences between
products.
Data Models
Level of Abstraction
Data Independency
Data Models
Traditional Models
There are three types of traditional models:
Hierarchichal Model
Network Model
Relational Model
Hierarchical model
Hierarchical Model.
One limitation of the hierarchical model is its inability to efficiently represent redundancy
in data. Entity-Attribute-Value database models like Caboodle by Swink are based on
this structure.
Parent–child relationship: Child may only have one parent but a parent can have multiple
children. Parents and children are tied together by links called "pointers“. A parent will
have a list of pointers to each of their children.
Network model
Network Model.
The network model organizes data using two fundamental constructs, called records and
sets. Records contain fields (which may be organized hierarchically, as in the
programming language COBOL). Sets (not to be confused with mathematical sets)
define one-to-many relationships between records: one owner, many members. A record
may be an owner in any number of sets, and a member in any number of sets.
The network model is a variation on the hierarchical model, to the extent that it is built on
the concept of multiple branches (lower-level structures) emanating from one or more
nodes (higher-level structures), while the model differs from the hierarchical model in
that branches can be connected to multiple nodes. The network model is able to represent
redundancy in data more efficiently than in the hierarchical model.
The operations of the network model are navigational in style: a program maintains a
current position, and navigates from one record to another by following the relationships
in which the record participates. Records can also be located by supplying key values.
Most object databases use the navigational concept to provide fast navigation across
networks of objects, generally using object identifiers as "smart" pointers to related
objects. Objectivity/DB, for instance, implements named 1:1, 1:many, many:1 and
many:many named relationships that can cross databases. Many object databases also
support SQL, combining the strengths of both models.
Relational model
Example of a Relational Model.
The relational model was introduced by E. F. Codd in 1970 as a way to make database
management systems more independent of any particular application. It is a mathematical
model defined in terms of predicate logic and set theory.
The products that are generally referred to as relational databases in fact implement a
model that is only an approximation to the mathematical model defined by Codd. Three
key terms are used extensively in relational database models: relations, attributes, and
domains. A relation is a table with columns and rows. The named columns of the relation
are called attributes, and the domain is the set of values the attributes are allowed to take.
The basic data structure of the relational model is the table, where information about a
particular entity (say, an employee) is represented in columns and rows (also called
tuples). Thus, the "relation" in "relational database" refers to the various tables in the
database; a relation is a set of tuples. The columns enumerate the various attributes of the
entity (the employee's name, address or phone number, for example), and a row is an
actual instance of the entity (a specific employee) that is represented by the relation. As a
result, each tuple of the employee table represents various attributes of a single employee.
A relational database contains multiple tables, each similar to the one in the "flat"
database model. One of the strengths of the relational model is that, in principle, any
value occurring in two different records (belonging to the same table or to different
tables), implies a relationship among those two records. Yet, in order to enforce explicit
integrity constraints, relationships between records in tables can also be defined
explicitly, by identifying or non-identifying parent-child relationships characterized by
assigning cardinality (1:1, (0)1:M, M:M). Tables can also have a designated single
attribute or a set of attributes that can act as a "key", which can be used to uniquely
identify each tuple in the table.
Conclusion
Various techniques are used to model data structure. Most database systems are built
around one particular data model, although it is increasingly common for products to
offer support for more than one model. For any one logical model various physical
implementations may be possible, and most products will offer the user some level of
control in tuning the physical implementation, since the choices that are made have a
significant effect on performance.