Primary Key Guidelines
Primary Key Guidelines
Primary Key Guidelines
Guidelines
First you should understand the function of a primary key.
Primary key s main function is to uniquely identify an entity
instance or row within the table.
The function of the primary key is to guarantee entity
integrity, not to describe the entity.
Second, primary keys and foreign keys are used to
implement relationships among the entities.
In the real world , end users identify objects based on
the characteristics they know about the object.
PK Characteristic RATIONALE
Unique values The PK must uniquely identify each entity
instance. A primary key must be able to
guarantee unique values. It cannot contain nulls.
Non intelligent The PK should not have embedded semantic
meaning other than to uniquely identify each
entity instance. An attribute with embedded
semantic meaning is probably better used as
descriptive characteristic of the entity than as an
identifier. For example , a student ID of 650973
would be preferred over Smith Martha L. as a
primary key Identifier.
No change over
time
If the attribute has a semantic meaning , it might
be subject to update. This is why names do not
make good primary keys. If you have Vickie
Smith as the primary key ,what happen is she
changes her name when she gets married ?if a
primary key is subject to change , the foreign
key values must be updated, thus adding to the
data base work load, Furthermore , changing a
primary key value means that you are basically
changing the identify of an entity. In short, the
PK should be permanent and unchageable.
PK Characteristic Rationale
Preferably single-
attribute
A primary key should have the minimum number of
attributes possible(irreducible). Single attribute
primary keys are desirable but not required .Single
attribute primary key simplify the implementation of
foreign keys having multiple attribute primary
keys can cause primary key related entities to grow
through the possible addition of the many
attributes , thus adding to the data base work load
and making (application) coding more
cumbersome.
Preferably
Unique values can be better managed when they
are numeric, because the database can use
internal routines to implement a counter style
attribute that automatically increments values with
the addition of each new row. In fact most
database systems include the ability to use special
construct, such as Auto number in the Microsoft
Access , to support self incrementing primary key
attributes.
Self compliant
The selected primary key must not be composed of
any attribute(s) that might be considered a security
risk or violation. For example , using n a social
security number as a PK in an employee table is
not a good idea..