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

關聯定義

數據表的關聯 " /> 午夜成a人片在线观看,亚洲天码中字,日本漂亮妈妈7观整有限中

天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

ThinkPHP關聯模型操作實例分析

通常我們所說的關聯關系包括下面三種:

◇ 一對一關聯 : 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" );

php技術ThinkPHP關聯模型操作實例分析,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: RAPPER性骚扰大开黄腔 | 2021国产精品 | 十九禁啊啪射视频在线观看 | 天天久久狠狠色综合 | 亚洲伊人久久大香线蕉综合图片 | 国产AV麻豆出品在线播放 | 日韩欧美精品有码在线播放免费 | 国产精品人妻无码久久久蜜桃 | 小SAO货叫大声点妓女 | 免费观看成人www精品视频在线 | 网友自拍偷拍 | 午夜福利视频极品国产83 | 老司机试看午夜 | 巨爆乳中文字幕爆乳区 | 久久午夜一区二区 | 少妇系列之白嫩人妻 | 日本欧美久久久久免费播放网 | 男男校园园bl文全肉高h寝室 | 狠狠色丁香久久婷婷综合_中 | 亚洲性夜夜夜色综合网 | AV色蜜桃一区二区三区 | 收集最新中文国产中文字幕 | 成片免费观看视频在线网 | 亚洲AV久久无码精品热九九 | 久久国产精品永久免费网站 | 俄罗斯女人Z0Z0极品 | 娇小萝被两个黑人用半米长 | 国产精品青青青高清在线密亚 | 久久成人免费大片 | 国内精品视频一区二区在线观看 | 中文字幕一区二区三区在线不卡 | 一区二区三区无码高清视频 | 男人桶女人j的视频在线观看 | 免费韩国伦理2017最新 | 国产露脸150部国语对白 | 双性精跪趴灌满h室友4p | 娇喘嗯嗯 轻点啊视频福利 娇喘高潮教室h | 肉动漫h黄动漫日本免费观看 | 十大禁止安装的黄台有风险 | 免费特黄一区二区三区视频一 | 青草影院内射中出高潮-百度 |