表的關聯(續)

如何定義表關聯?

$belongsTo

 

定義從屬關聯

1、外鍵放置在主表中; �
2、保存時不會自動更新關聯表的記錄; �
3、刪除時也不會更新關聯表的記錄。

示例: �
多個文章都屬於某一個欄目。

格式一:  

    * class Articles
    * {
    *      var $belongsTo = array(
    *          array(
    *              ‘tableClass’  => ‘Columns’,
    *              ‘foreignKey’  => ‘column_id’,
    *              ‘mappingName’ => ‘column’
    *          ),
    *      );
    * }

在上面的格式中,foreignKey 表示在當前表中用什麼字段存儲對關聯表的主鍵引用。 �
mappingName 表示在主表的返回結果中,以什麼名字保存關聯表的數據。 �
如果不提供 mappingName 參數,則假定使用 tableClass。

格式二:  

    * class Articles
    * {
    *      var $belongsTo = ‘Columns’;
    * }

格式二是一種簡化寫法。foreignKey 字段名將和關聯表的主鍵字段名相同。

============================

$hasMany

定義一對多關聯

1、外鍵保存在關聯表中; �
2、保存時自動更新關聯表的記錄; �
3、刪除主表記錄時自動刪除關聯記錄。

示例: �
每個用戶(user)有多張訂單 order。

格式一:  

    * class Users
    * {
    *      var $hasMany = array(
    *          array(
    *              ‘tableClass’  => ‘Orders’,
    *              ‘foreignKey’  => ‘user_id’,
    *              ‘mappingName’ => ‘orders’,
    *          ),
    *      );
    * }

在一對多關係中,當前表並不包含對關聯表的主鍵引用。 �
而是在關聯表中保存對當前表的主鍵引用。
在上面的格式中,foreignKey 指示在關聯表中用什麼字段存儲對當前表的主鍵引用。 �
mappingName 表示在主表的返回結果中,以什麼名字保存關聯表的數據。 �
如果不提供 mappingName 參數,則假定使用 tableClass。

格式二:  

    * class Users
    * {
    *      var $hasMany = ‘Orders’;
    * }

簡化寫法中,foreignKey 字段名將和當前表的主鍵字段名相同。

============================

$hasOne

定義一對一關聯
1、外鍵放置在關聯表中;
2、保存時如果有關聯對象,則自動創建或更新關聯表的記錄; �
3、刪除主表記錄時自動刪除關聯記錄。

示例: �
當前表爲 users,用於存儲用戶賬戶。而每個用戶賬戶有且只有一個對應的個人信息(profile)記錄。

格式一:  

    * class Users
    * {
    *      var $hasOne = array(
    *          array(
    *              ‘tableClass’  => ‘Profiles’,
    *              ‘foreignKey’  => ‘profile_id’,
    *              ‘mappingName’ => ‘profile’,
    *          ),
    *      );
    * }

在上面的格式中,foreignKey 表示在關聯表中用什麼字段存儲對主表的主鍵引用。  mappingName 表示在主表的返回結果中,以什麼名字保存關聯表的數據。  如果不提供 mappingName 參數,則假定使用 tableClass。

格式二:  

    * class Users
    * {
    *      var $hasOne = ‘Profiles’;
    * }

格式二是一種簡化寫法。foreignKey 字段名將和主表的主鍵字段名名相同。

============================

$manyToMany
     �
定義多對多關聯

1、外鍵保存在中間表裏面;
2、保存時自動更新中間表; �
3、刪除主表記錄時自動刪除中間表的相關記錄。

示例: �
每個成員(member)可以擁有多個角色(role),而每個角色也可以指定給多個成員。

格式一:  

    * class Members
    * {
    *      var $manyToMany = array(
    *          array(
    *              ‘tableClass’      => ‘Roles’,
    *              ‘joinTable’       => ‘member_roles’,
    *              ‘foreignKey’      => ‘member_id’,
    *              ‘assocforeignKey’ => ‘role_id’,
    *              ‘mappingName’     => ‘roles’,
    *          ),
    *      );
    * }

在多對多關係中,當前表並不包含對關聯表的主鍵引用。 �
而是在一箇中間表裏面保存對當前表和關聯表的主鍵引用。
在上面的格式中,joinTable 表示中間表的名字。foreignKey 和 �
assocforeignKey 分別表示在中間表裏面用什麼字段存儲對主表和 �
關聯表主鍵字段的引用。

mappingName 表示在主表的返回結果中,以什麼名字保存關聯表的數據。 �
如果不提供 mappingName 參數,則假定使用 tableClass。

格式二:  

    * class Members
    * {
    *      var $manyToMany = ‘Roles’;
    * }

簡化寫法中,foreignKey 字段名將和當前表的主鍵字段名相同。
assocforeignKey字段名稱則和關聯數據表的主鍵字段名相同。
而中間表名稱將用FLEA_Db_TableDataGateway::getMidtableName() 方法計算。

發佈了41 篇原創文章 · 獲贊 0 · 訪問量 16萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章