肉色超薄丝袜脚交一区二区,香蕉久久av一区二区三区,男人进入女人下部视频,被几个人强的好爽小说

中山php|最優網絡中山做網站 中山php建站

最優良人

2011/09/06 at 18:06

FleaPHP如何定義表關聯以及關聯的簡寫

定義從屬關聯

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() 方法計算。

hasOne 是一對多關聯,表示一條主表記錄有一條對應的關聯記錄。
而 belongsTo 是從屬關聯,表示一條主表記錄屬于另一條關聯記錄。

hasOne 和 belongsTo 正好是相反的關系。

例如 “一個用戶”有一個“個人空間”。那么一個“個人空間”就屬于“一個用戶”。

由于 hasOne 實際上是 hasMany (一對多)關聯的一種特例,所以 belongsTo 和 hasMany 也是相反的關系。

標簽:,
-
主站蜘蛛池模板: 沙洋县| 沂南县| 闵行区| 沁源县| 托里县| 武陟县| 宽城| 成武县| 柞水县| 峨眉山市| 府谷县| 富裕县| 罗山县| 嘉义县| 鄂托克前旗| 丰台区| 铁岭市| 霍山县| 炎陵县| 镇远县| 白河县| 揭东县| 清远市| 闸北区| 榆中县| 大渡口区| 萨嘎县| 安塞县| 韩城市| 安顺市| 工布江达县| 剑阁县| 周口市| 新宾| 泌阳县| 高碑店市| 中西区| 开远市| 重庆市| 高要市| 颍上县|