Skip to main content

Foreign Keys



A foreign key relationship allows for the declaration of an index in one table to be related to an index in another.  It also allows for the placing of constraints on what may be done to the tables in the relationship.  The database enforces the rules of this relationship to maintain referential integrity. Using Foreign Keys with InnoDB The InnoDB storage engine supports the use of foreign keys (unlike other storage engines).  This capability enables the declaration of relationships between columns in different tables, and InnoDB maintains integrity between the tables by prohibiting operations that violate those relationships.  For example, the following restrictions must be addressed:  

•  A table must contain only records with ID values that are known in another reference table.  

•  If an ID in the referenced table is changed, the ID in all matching records in the referencing table must be changed to match.  

•  If a record with a given ID in the referenced table is deleted, all records with the matching ID in the referencing table must also be deleted.  The following example demonstrates some of the ways in which InnoDB provides referential integrity between tables.  It shows how to define a foreign key relationship that enforces the requirements just described.  The example is based on the implicit relationship between the Country and City tables in the world database: 

•  Each Country record has a Code column that specifies a unique country code.  

•  Each City record has a CountryCode column that matches the code for the country in which the city is located.  The relationship is only implicit because Country and City are MyISAM tables: MyISAM does not have any syntax for specifying the relationship explicitly and provides no means for enforcing it. This means that Code value could be changed in the Country table and any City records with the corresponding country code would not be changed to match.  A Country table row could be deleted but the corresponding City records would not be deleted.  In either case, the City records would become orphaned because there is no longer any corresponding Country table record for them.  InnoDB does not allow these types of referential 
integrity failures to occur.  



To define a country-city relationship explicitly, derive a couple of  InnoDB tables from the MyISAM tables. We'll call these tables country_parent and city_child to illustrate that the country records are the parent records and the city records are the child records that depend on them:  


CREATE TABLE country_parent 

    code CHAR(3) NOT NULL, 
    name CHAR(52) NOT NULL, 
    PRIMARY KEY (code) 
) ENGINE = InnoDB; 

CREATE TABLE city_child 

    id           INT NOT NULL AUTO_INCREMENT, 
    name         CHAR(35) NOT NULL, 
   country_code CHAR(3) NOT NULL, 
    PRIMARY KEY (ID), 
    INDEX (country_code), 
    FOREIGN KEY (country_code) 
        REFERENCES country_parent (code) 
        ON UPDATE CASCADE 
       ON DELETE CASCADE 
) ENGINE = InnoDB; 




In these two tables, the column and PRIMARY KEY definitions are the same as in the original Country and City tables. The parts of the syntax that differ from the original tables are the ENGINE table option, which specifies the InnoDB storage engine, and the  INDEX and  FOREIGN KEY definitions for the CountryCode column in the city_child table.  

Comments

Popular posts from this blog

PHP INTRODUCTION

                     PHP  (recursive acronym for  PHP: Hypertext Preprocessor ) is a widely-used open source general-purpose scripting language that is especially suited for web development and can be embedded into HTML. PHP stands for  P HP:  H ypertext  P reprocessor PHP is a server-side scripting language, like ASP PHP scripts are executed on the server PHP supports many databases (MySQL, Informix, Oracle, Sybase, Solid, PostgreSQL, Generic ODBC, etc.) PHP is an open source software PHP is free to download and use Why PHP? PHP runs on different platforms (Windows, Linux, Unix, etc.) PHP is compatible with almost all servers used today (Apache, IIS, etc.) PHP is FREE to download from the official PHP resource:  www.php.net PHP is easy to learn and runs efficiently on the server side What can PHP do? Anything. PHP is mainly focused on server-side scripting, so you can...

Storage Engine Breakdown

The following diagram represents a simplified view of the MySQL server and its interaction with the  storage engines. The following properties are storage engine dependant: • Storage Medium – Each table uses its own method of storing the data it contains. • Transactional Capabilities – Certain storage engines handle transactional processing which ensures that integrity of a database is maintained during the processing of multiple SQL statements.

Outer Joins

Whereas an INNER JOIN will find combinations of matching rows from joined tables, the OUTER JOIN also finds the instances where a row in one table has no match in another table. An OUTER JOIN find matches (just like an INNER JOIN), but also identifies mismatches. Two forms of outer joins are LEFT JOIN and RIGHT JOIN . These do not use the comma separator or the INNER JOIN keywords. They each answer the same kinds of questions, but differ slightly in their syntax. That is a LEFT JOIN can always be re-written into a equivalent RIGHT JOIN. (In the following sections, the terms left table and right table refer to the tables named first and second in the FROM clause, respectively.)  Left Outer Join A left join is a type of outer join, written using the LEFT JOIN keywords. A left join treats the left table (the first one named) as a reference table and produces output for each row selected from it, whether or not the row is matched by rows in the right table. Like a join w...