来源:自学PHP网 时间:2017-08-07 15:11 作者: 阅读:次
[导读] 这篇文章主要介绍了CakePHP框架Model关联对象用法,结合实例形式分析了cakePHP框架Model关联对象的功能、定义及具体使用方法,需要的朋友可以参考下...
|
本文实例讲述了CakePHP框架Model关联对象。分享给大家供大家参考,具体如下: CakePHP 提供关联数据表间的映射,共有4种类型的关联:
设定了Model间的关联关系定义,CakePHP就会将基于关系数据库的数据映射为基于对象的关系模型。 但是你应该确保遵循CakePHP的命名规则. 命名规则中需要考虑的3个内容是,外键,model名字,表名. 外键:单数形式的 modelName_id hasOne 关联的定义与查询:通过在model中增加一个array来实现.
class User extends AppModel
{
var $name = 'User';
var $hasOne = array(
'UserInfos' => array(
'className' => 'UserInfos',
'conditions' => '',
'order'=> '',
'dependent' => true,
'foreignKey' => 'user_id'
)
);
}
$hasOne 变量是一个array,CakePHP 通过该变量来构建 Blog 与 User 之间的关联。 className: 关联对象的类名。 belongsTo 关联的定义与使用
class Blog extends AppModel
{
var $name = 'Blog';
var $belongsTo = array(
'User' => array(
'className' => 'User',
'conditions' => '',
'order' => '',
'foreignKey' => 'user_id'
)
);
}
className: 关联对象的类名。 hasMany 关联的定义与查询
class User extends AppModel
{
var $name = 'User';
var $hasMany = array(
'Blog' => array(
'className' => 'Blog',
'conditions' => 'Blog.status = 1',
'order' => 'Blog.created DESC',
'limit' => '5',
'foreignKey' => 'user_id',
'dependent' => true,
'exclusive' => false, 'finderQuery' => ''
)
);
}
$hasMany array 用来定义 User 包含多条 Blog 这样的关联关系。 className: 关联对象类名。 limit: 用 limit 来限定检索的关联对象数量。 foreignKey: 外键字段名。 同样可以为 Blog 加上关联 User 对象的 belongTo 关联。 hasAndBelongsToMany 关联的定义与查询。
class Blog extends AppModel
{
var $name = 'Blog';
var $hasAndBelongsToMany = array('Tag' =>
array('className' => 'Tag',
'joinTable' => 'blogs_tags',
'foreignKey' => 'blog_id',
'associationForeignKey'=> 'tag_id',
'conditions' => '',
'order' => '',
'limit' => '',
'uniq' => true,
'finderQuery' => '',
'deleteQuery' => '',
)
);
}
$hasAndBelongsToMany array 是定义 HABTM 关联的变量。 className: 关联对象类名。 保存关联对象: 当关联的两个对象都没有持久化,你需要首先持久化主对象。 在保存子对象时要把父对象的 ID 保持在子对象中。 保存 hasAndBelongsToMany 关联对象: 使用 更多关于php框架相关内容感兴趣的读者可查看本站专题:、、、、、 希望本文所述对大家PHP程序设计有所帮助。 |
自学PHP网专注网站建设学习,PHP程序学习,平面设计学习,以及操作系统学习
京ICP备14009008号-1@版权所有www.zixuephp.com
网站声明:本站所有视频,教程都由网友上传,站长收集和分享给大家学习使用,如由牵扯版权问题请联系站长邮箱904561283@qq.com