Wednesday, April 18, 2007
Oracle 6
INTRODUCTION
According to Elmasri and Navathe (1994), Dr. E. F. Codd, the originator of the relational
data model, published a two-part article in ComputerWorld (Codd, 1985) that lists 12 rules for
how to determine whether a DBMS is relational and to what extent it is relational. These rules
provide a very useful yardstick for evaluating a relational system. Codd also mentions that,according to these rules, no fully relational system is available yet. In particular, rules 6, 9, 10, 11,
and 12 are difficult to satisfy.
THE 12 RULES
Rule 1: The Information Rule
All information in a relational database is represented explicitly at the logical level in
exactly one way by values in tables.
All data is represented in the form of relations/tables (with rows and columns)Simple
Consistent and versatile
Rule 2: Guaranteed Access Rule
Each and every datum (atomic value) in a relational database is guaranteed to be logically
accessible by resorting to a table name, primary key value, and column name. All Data is uniquely
identified and accessible via this identity.
Rule 3: Systematic Treatment of Null Values
Null values (distinct from empty character string or a string of blank characters and distinct
from zero or any other number) are supported in the fully relational DBMS for representing
missing information in a systematic way, independent of data type.
Rule 4: Dynamic On-line Catalog based on the Relational Model
The database description is represented at the logical level in the same way as ordinary
data, so authorized users can apply the same relational language to its interrogation as they apply
to regular data.
Rule 5: Comprehensive Data Sublanguage Rule
A relational system may support several languages and various modes of terminal use (for
example, the fill-in-blanks mode). However, there must be at least one language whose statements
are expressible, per some well-defined syntax, as character strings and whose ability to support all
of the following is comprehensible: data definition, view definition, data manipulation (interactive
and by program), integrity constraints, and transaction boundaries (begin, commit, and rollback).
Rule 6: View Updating Rule
All views that are theoretically updateable are also updateable by the system.
Views are virtual tables. They appear to behave as conventional tables except that they are built
dynamically when the query is run. This means that a view is always up to date. It is not always
theoretically possible to update views. One problem exists when a view relates to part of a table
not including a candidate key. This means that potential updates would violate the entity integrity
rule.
Rule 7: High-level Insert, Update, and Delete
The capability of handling a base relation or a derived relation as a single operand applies
not only to the retrieval of data but also to the insertion, update, and deletion of data. i.e. The user
should be allowed to Delete, Update a set of tuples (rather than row by row)
Rule 8: Physical Data Independence
Application programs and terminal activities remain logically unimpaired whenever any
changes are made in either storage representation or access methods. i.e. Users and programs are
not dependent on the physical structure of the database.
Rule 9: Logical Data Independence
Application programs and terminal activities remain logically unimpaired when
information-preserving changes of any kind that theoretically permit unimpairment are made to
the base tables. Users and Programs are independent of the logical structure of the database, i.e.
the logical structure of the data can evolve with minimal impact on the programs.
Rule 10: Integrity Independence
Integrity constraints specific to a particular relational database must be definable in the
relational data sublanguage and storable in the catalog, not in the application programs. A
minimum of the following two integrity constraints must be supported:
1. Entity integrity: No component of a primary key is allowed to have a null value.
2. Referential integrity: For each distinct non-null foreign key value in a relational database,
there must exist a matching primary key value from the same domain.
Rule 11: Distribution Independence
A relational DBMS has distribution independence. Distribution independence implies that
users should not have to be aware of whether a database is distributed. Applications should still
work in a distributed database (DDB).
Rule 12: Nonsubversion Rule
If a relational system has a low-level (single-record-at-a-time) language, that low-level
language cannot be used to subvert or bypass the integrity rules or constraints expressed in the
higher-level (multiple-records-at-a-time) relational language.
If there is a record at a time interface (e.g. via 3GL), Security and integrity of the database
must no be violated. There should be no backdoor to bypass the security imposed by the DBMS.
On the basis of the above rules, there is no fully relational DBMS available today.
According to Elmasri and Navathe (1994), Dr. E. F. Codd, the originator of the relational
data model, published a two-part article in ComputerWorld (Codd, 1985) that lists 12 rules for
how to determine whether a DBMS is relational and to what extent it is relational. These rules
provide a very useful yardstick for evaluating a relational system. Codd also mentions that,according to these rules, no fully relational system is available yet. In particular, rules 6, 9, 10, 11,
and 12 are difficult to satisfy.
THE 12 RULES
Rule 1: The Information Rule
All information in a relational database is represented explicitly at the logical level in
exactly one way by values in tables.
All data is represented in the form of relations/tables (with rows and columns)Simple
Consistent and versatile
Rule 2: Guaranteed Access Rule
Each and every datum (atomic value) in a relational database is guaranteed to be logically
accessible by resorting to a table name, primary key value, and column name. All Data is uniquely
identified and accessible via this identity.
Rule 3: Systematic Treatment of Null Values
Null values (distinct from empty character string or a string of blank characters and distinct
from zero or any other number) are supported in the fully relational DBMS for representing
missing information in a systematic way, independent of data type.
Rule 4: Dynamic On-line Catalog based on the Relational Model
The database description is represented at the logical level in the same way as ordinary
data, so authorized users can apply the same relational language to its interrogation as they apply
to regular data.
Rule 5: Comprehensive Data Sublanguage Rule
A relational system may support several languages and various modes of terminal use (for
example, the fill-in-blanks mode). However, there must be at least one language whose statements
are expressible, per some well-defined syntax, as character strings and whose ability to support all
of the following is comprehensible: data definition, view definition, data manipulation (interactive
and by program), integrity constraints, and transaction boundaries (begin, commit, and rollback).
Rule 6: View Updating Rule
All views that are theoretically updateable are also updateable by the system.
Views are virtual tables. They appear to behave as conventional tables except that they are built
dynamically when the query is run. This means that a view is always up to date. It is not always
theoretically possible to update views. One problem exists when a view relates to part of a table
not including a candidate key. This means that potential updates would violate the entity integrity
rule.
Rule 7: High-level Insert, Update, and Delete
The capability of handling a base relation or a derived relation as a single operand applies
not only to the retrieval of data but also to the insertion, update, and deletion of data. i.e. The user
should be allowed to Delete, Update a set of tuples (rather than row by row)
Rule 8: Physical Data Independence
Application programs and terminal activities remain logically unimpaired whenever any
changes are made in either storage representation or access methods. i.e. Users and programs are
not dependent on the physical structure of the database.
Rule 9: Logical Data Independence
Application programs and terminal activities remain logically unimpaired when
information-preserving changes of any kind that theoretically permit unimpairment are made to
the base tables. Users and Programs are independent of the logical structure of the database, i.e.
the logical structure of the data can evolve with minimal impact on the programs.
Rule 10: Integrity Independence
Integrity constraints specific to a particular relational database must be definable in the
relational data sublanguage and storable in the catalog, not in the application programs. A
minimum of the following two integrity constraints must be supported:
1. Entity integrity: No component of a primary key is allowed to have a null value.
2. Referential integrity: For each distinct non-null foreign key value in a relational database,
there must exist a matching primary key value from the same domain.
Rule 11: Distribution Independence
A relational DBMS has distribution independence. Distribution independence implies that
users should not have to be aware of whether a database is distributed. Applications should still
work in a distributed database (DDB).
Rule 12: Nonsubversion Rule
If a relational system has a low-level (single-record-at-a-time) language, that low-level
language cannot be used to subvert or bypass the integrity rules or constraints expressed in the
higher-level (multiple-records-at-a-time) relational language.
If there is a record at a time interface (e.g. via 3GL), Security and integrity of the database
must no be violated. There should be no backdoor to bypass the security imposed by the DBMS.
On the basis of the above rules, there is no fully relational DBMS available today.
Subscribe to:
Post Comments (Atom)
4 comments:
thanks, I am trying to learn database
This post gives you introduction about Oracle 6. This post is very useful for beginners as they get to know lot of things about Oracle 6. I find this very informative.I really your work. This is incredible work. Thanks for the post.
Good day! I know this is kinda off topic but I'd figured I'd ask.
Would you be interested in exchanging links or maybe guest authoring a
blog post or vice-versa? My blog discusses
a lot of the same subjects as yours and I believe we could greatly benefit from each other.
If you are interested feel free to shoot me an e-mail.
I look forward to hearing from you! Terrific blog by the way!
Also visit my web blog - voyance Par telephone
Hello! This post couldn't be written any better! Reading this post reminds me of my good old room mate! He always kept talking about this. I will forward this article to him. Fairly certain he will have a good read. Thank you for sharing!
Also visit my page: voyance
Post a Comment