2007-04-13 21:49:11 +00:00
|
|
|
A foreign key constraint specifies that the values in a column (or a group of columns) must match the values appearing in some row of another table. In other words foreign key constraints maintain the referential integrity between two related tables.
|
|
|
|
|
|
|
|
Say you have the product table with the following definition:
|
|
|
|
|
|
|
|
<code type='php'>
|
2007-05-11 19:23:18 +00:00
|
|
|
class Product extends Doctrine_Record
|
2007-04-13 21:49:11 +00:00
|
|
|
{
|
2007-05-11 19:23:18 +00:00
|
|
|
public function setTableDefinition()
|
2007-04-13 21:49:11 +00:00
|
|
|
{
|
|
|
|
$this->hasColumn('id', 'integer', null, 'primary');
|
|
|
|
$this->hasColumn('name', 'string');
|
2007-05-11 19:23:18 +00:00
|
|
|
$this->hasColumn('price', 'decimal', 18);
|
2007-04-13 21:49:11 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
</code>
|
|
|
|
|
|
|
|
Let's also assume you have a table storing orders of those products. We want to ensure that the order table only contains orders of products that actually exist. So we define a foreign key constraint in the orders table that references the products table:
|
|
|
|
|
|
|
|
<code type='php'>
|
|
|
|
class Order extends Doctrine_Record
|
|
|
|
{
|
2007-05-11 19:23:18 +00:00
|
|
|
public function setTableDefinition()
|
2007-04-13 21:49:11 +00:00
|
|
|
{
|
|
|
|
$this->hasColumn('order_id', 'integer', null, 'primary');
|
|
|
|
$this->hasColumn('product_id', 'integer');
|
|
|
|
$this->hasColumn('quantity', 'integer');
|
|
|
|
}
|
|
|
|
public function setUp()
|
|
|
|
{
|
|
|
|
$this->hasOne('Product', 'Order.product_id');
|
2007-05-11 19:23:18 +00:00
|
|
|
|
2007-04-13 21:49:11 +00:00
|
|
|
// foreign key columns should *always* have indexes
|
2007-05-11 19:23:18 +00:00
|
|
|
|
2007-04-13 21:49:11 +00:00
|
|
|
$this->index('product_id', array('fields' => 'product_id'));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
</code>
|
|
|
|
|
2007-05-11 19:23:18 +00:00
|
|
|
When exported the class 'Order' would execute the following sql:
|
2007-04-13 21:49:11 +00:00
|
|
|
|
|
|
|
CREATE TABLE orders (
|
|
|
|
order_id integer PRIMARY KEY,
|
|
|
|
product_id integer REFERENCES products (id),
|
|
|
|
quantity integer,
|
|
|
|
INDEX product_id_idx (product_id)
|
|
|
|
)
|
|
|
|
|
|
|
|
Now it is impossible to create orders with product_no entries that do not appear in the products table.
|
|
|
|
|
2007-05-11 19:23:18 +00:00
|
|
|
We say that in this situation the orders table is the referencing table and the products table is the referenced table. Similarly, there are referencing and referenced columns.
|