ThinkPHP關聯模型操作執行個體分析_PHP教程

來源:互聯網
上載者:User
通常我們所說的關聯關係包括下面三種:

◇ 一對一關聯 : ONE_TO_ONE , 包括 HAS_ONE 和 BELONGS_TO
◇ 一對多關聯 : ONE_TO_MANY , 包括 HAS_MANY 和 BELONGS_TO
◇ 多對多關聯 : MANY_TO_MANY

關聯定義

資料表的關聯 CURD 操作,目前支援的關聯關係包括下面四種:HAS_ONE 、 BELONGS_TO 、 HAS_MANY 、 MANY_TO_MANY 。

一個模型根據業務模型的複雜程度可以同時定義多個關聯,不受限制,所有的關聯定義都統一在模型類的 $_link 成員變數裡面定義,並且可以支援動態定義。要支援關聯操作,模型類必須繼承 RelationModel 類,關聯定義的格式是:
複製代碼 代碼如下:
protected $_link = array(
' 關聯 1' => array(
' 關聯屬性 1' => ' 定義 ',
' 關聯屬性 N' => ' 定義 ',
),
' 關聯 2' => array(
' 關聯屬性 1' => ' 定義 ',
' 關聯屬性 N' => ' 定義 ',
),
...
);

HAS_ONE 關聯方式的定義:
複製代碼 代碼如下:
class UserModel extends RelationModel
{
public $_link = array(
'Profile'=> array(
'mapping_type' =>HAS_ONE,
'class_name'=>'Profile',
// 定義更多的關聯屬性
……
) ,
);
}

mapping_type 關聯類別型,這個在 HAS_ONE 關聯裡面必須使用 HAS_ONE 常量定義。
class_name 要關聯的模型類名
mapping_name 關聯的映射名稱,用於擷取資料用
foreign_key 關聯的外鍵名稱
condition 關聯條件
mapping_fields 關聯要查詢的欄位
as_fields 直接把關聯的欄位值對應成資料對象中的某個欄位

BELONGS_TO 關聯方式的定義:
複製代碼 代碼如下:
'Dept'=> array(
'mapping_type'=>BELONGS_TO,
'class_name'=>'Dept',
'foreign_key'=>'userId',
'mapping_name'=>'dept',
// 定義更多的關聯屬性
……
) ,

class_name 要關聯的模型類名
mapping_name 關聯的映射名稱,用於擷取資料用
foreign_key 關聯的外鍵名稱
mapping_fields 關聯要查詢的欄位
condition 關聯條件
parent_key 自引用關聯的關聯欄位
as_fields 直接把關聯的欄位值對應成資料對象中的某個欄位

HAS_MANY 關聯方式的定義:
複製代碼 代碼如下:
'Article'=> array(
'mapping_type' =>HAS_MANY,
'class_name'=>'Article',
'foreign_key'=>'userId',
'mapping_name'=>'articles',
'mapping_order'=>'create_time desc',
// 定義更多的關聯屬性
……
) ,

class_name 要關聯的模型類名
mapping_name 關聯的映射名稱,用於擷取資料用
foreign_key 關聯的外鍵名稱
parent_key 自引用關聯的關聯欄位
condition 關聯條件
mapping_fields 關聯要查詢的欄位
mapping_limit 關聯要返回的記錄數目
mapping_order 關聯查詢的排序

MANY_TO_MANY 關聯方式的定義:
複製代碼 代碼如下:
"Group"=>array(
'mapping_type'=>MANY_TO_MANY,
'class_name'=>'Group',
'mapping_name'=>'groups',
'foreign_key'=>'userId',
'relation_foreign_key'=>'goupId',
'relation_table'=>'think_gourpUser'
)

class_name 要關聯的模型類名
mapping_name 關聯的映射名稱,用於擷取資料用
foreign_key 關聯的外鍵名稱
relation_foreign_key 關聯表的外鍵名稱
mapping_limit 關聯要返回的記錄數目
mapping_order 關聯查詢的排序
relation_table 多對多的中間關聯表名稱

關聯查詢

使用 relation 方法進行關聯操作, relation 方法不但可以啟用關聯還可以控制局部關聯操作,實現了關聯操作一切盡在掌握之中。

$User = D( "User" );
$user = $User->realtion(true)->find(1);

輸出 $user 結果可能是類似於下面的資料:
複製代碼 代碼如下:
array(
'id'=>1,
'account'=>'ThinkPHP',
'password'=>'123456',
'Profile'=> array(
'email'=>'liu21st@gmail.com',
'nickname'=>'流年',
) ,
)

關聯寫入
複製代碼 代碼如下:
$User = D( "User" );
$data = array();
$data["account"]="ThinkPHP";
$data["password"]="123456";
$data["Profile"]=array(
'email'=>'liu21st@gmail.com',
'nickname' =>' 流年 ',
) ;
$result = $User->relation(true)->add($user);

這樣就會自動寫入關聯的 Profile 資料。

關聯更新
複製代碼 代碼如下:
$User = D( "User" );
$data["account"]= "ThinkPHP";
$data["password"]= "123456";
$data["Profile"]=array(
'email'=>'liu21st@gmail.com',
'nickname' =>' 流年 ',
) ;
$result =$User-> relation(true)->where(‘id=3')->save($data);

關聯刪除

$result =$User->relation(true)->delete( "3" );

http://www.bkjia.com/PHPjc/325937.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/325937.htmlTechArticle通常我們所說的關聯關係包括下面三種: ◇ 一對一關聯 : ONE_TO_ONE , 包括 HAS_ONE 和 BELONGS_TO ◇ 一對多關聯 : ONE_TO_MANY , 包括 HAS_MANY 和...

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.