CakePHP - 关系问题 - Posts.Child属于用户,如何定义?

时间:2011-08-08 13:52:04

标签: cakephp children belongs-to posts

下面是一个帖子模型,正如您所看到的,我在每个帖子上都有一个belongsTo关系,因此也可以使用帖子检索用户详细信息。 我还想为Posts.Children提供完全相同的行为(请参阅下面的hasMany定义)。

问题:

我如何将belongsTo关系应用于Posts.Children(Posts.Child belongsTo User)??

<?php
class Post extends AppModel {

    var $name = 'Post';

    var $belongsTo = array(
        'User' => array(
            'className' => 'User',
            'foreignKey' => 'post_owner',
          'fields' => array( "User.id" , "User.first_name" , "User.last_name" )
        )
    );

    // -=> 
    var $hasMany = array(
        'Child' => array(
            'className' => 'Post',
            'foreignKey' => 'parent_id',
        'conditions' => array( "Child.active" => "1" ),
        'limit' => '2',
        'order' => 'time DESC'
        )
    );
}
?>

这是我目前正在使用的PostsController代码:

class PostsController extends AppController {    
    var $helpers = array ('Html','Form');
    var $name = 'Posts';

    function index() {
        $conditions = array( "Post.parent_id" => "0" , "Post.active" => "1" );
        $this->set(     'posts', $this->Post->find('all',array(   'conditions'=>$conditions     ))   );
        debug(   $this->Post->find('all',array(   'conditions'=>$conditions  ))   );
}

“如果你调用debug($ this-&gt; Post-&gt; Child),那么输出是什么;在posts控制器中?” 这是:

Post Object
(
    [name] => Post
    [hasMany] => Array
        (
            [Child] => Array
            (
                [className] => Post
                [foreignKey] => parent_id
                [conditions] => Array
                    (
                        [Child.active] => 1
                    )

                [fields] => 
                [order] => 
                [limit] => 
                [offset] => 
                [dependent] => 
                [exclusive] => 
                [finderQuery] => 
                [counterQuery] => 
            )

    )

[belongsTo] => Array
    (
        [User] => Array
            (
                [className] => User
                [foreignKey] => dom
                [fields] => Array
                    (
                        [0] => User.id
                        [1] => User.first_name
                        [2] => User.last_name
                    )

                [conditions] => 
                [order] => 
                [counterCache] => 
            )

    )

[useDbConfig] => default
[useTable] => posts
[displayField] => title
[id] => 
[data] => Array
    (
    )

[table] => posts
[primaryKey] => id
[_schema] => Array
    (
        [active] => Array
            (
                [type] => integer
                [null] => 
                [default] => 1
                [length] => 1
            )

        [id] => Array
            (
                [type] => integer
                [null] => 
                [default] => 
                [length] => 11
                [key] => primary
            )

        [parent_id] => Array
            (
                [type] => integer
                [null] => 
                [default] => 0
                [length] => 11
            )

        [time] => Array
            (
                [type] => integer
                [null] => 
                [default] => 0
                [length] => 11
            )

        [dom] => Array
            (
                [type] => integer
                [null] => 
                [default] => 
                [length] => 11
            )

        [sub] => Array
            (
                [type] => integer
                [null] => 
                [default] => 
                [length] => 11
            )

        [created] => Array
            (
                [type] => datetime
                [null] => 
                [default] => 
                [length] => 
            )

        [modified] => Array
            (
                [type] => datetime
                [null] => 
                [default] => 
                [length] => 
            )


        [text] => Array
            (
                [type] => string
                [null] => 
                [default] => 
                [length] => 4096
                [collate] => latin1_swedish_ci
                [charset] => latin1
            )

    )

[validate] => Array
    (
    )

[validationErrors] => Array
    (
    )

[tablePrefix] => 
[alias] => Child
[tableToModel] => Array
    (
        [posts] => Child
        [users] => User
    )

[logTransactions] => 
[cacheQueries] => 
[hasOne] => Array
    (
    )

[hasAndBelongsToMany] => Array
    (
    )

[actsAs] => 
[Behaviors] => BehaviorCollection Object
    (
        [modelName] => Child
        [_attached] => Array
            (
            )

        [_disabled] => Array
            (
            )

        [__methods] => Array
            (
            )

        [__mappedMethods] => Array
            (
            )

    )

[whitelist] => Array
    (
    )

[cacheSources] => 1
[findQueryType] => 
[recursive] => 1
[order] => 
[virtualFields] => Array
    (
    )

[__associationKeys] => Array
    (
        [belongsTo] => Array
            (
                [0] => className
                [1] => foreignKey
                [2] => conditions
                [3] => fields
                [4] => order
                [5] => counterCache
            )

        [hasOne] => Array
            (
                [0] => className
                [1] => foreignKey
                [2] => conditions
                [3] => fields
                [4] => order
                [5] => dependent
            )

        [hasMany] => Array
            (
                [0] => className
                [1] => foreignKey
                [2] => conditions
                [3] => fields
                [4] => order
                [5] => limit
                [6] => offset
                [7] => dependent
                [8] => exclusive
                [9] => finderQuery
                [10] => counterQuery
            )

        [hasAndBelongsToMany] => Array
            (
                [0] => className
                [1] => joinTable
                [2] => with
                [3] => foreignKey
                [4] => associationForeignKey
                [5] => conditions
                [6] => fields
                [7] => order
                [8] => limit
                [9] => offset
                [10] => unique
                [11] => finderQuery
                [12] => deleteQuery
                [13] => insertQuery
            )

    )

[__associations] => Array
    (
        [0] => belongsTo
        [1] => hasOne
        [2] => hasMany
        [3] => hasAndBelongsToMany
    )

[__backAssociation] => Array
    (
    )

[__insertID] => 
[__numRows] => 
[__affectedRows] => 
[_findMethods] => Array
    (
        [all] => 1
        [first] => 1
        [count] => 1
        [neighbors] => 1
        [list] => 1
        [threaded] => 1
    )

[User] => User Object
    (
        [name] => User
        [validate] => Array
            (
                [name] => Array
                    (
                        [rule] => Array
                            (
                                [0] => minLength
                                [1] => 4
                            )

                        [message] => Name has to be at least four characters
                    )

                [email] => Array
                    (
                        [rule] => Array
                            (
                                [0] => email
                            )

                        [message] => Please enter a valid email
                    )

                [username] => Array
                    (
                        [Username has to be at least four characters] => Array
                            (
                                [rule] => Array
                                    (
                                        [0] => minLength
                                        [1] => 4
                                    )

                            )

                        [This username is already taken, please try another] => Array
                            (
                                [rule] => isUnique
                            )

                    )

                [password] => Array
                    (
                        [Password cannot be empty] => Array
                            (
                                [rule] => Array
                                    (
                                        [0] => notEmpty
                                    )

                            )

                        [Password must be at least four characters] => Array
                            (
                                [rule] => Array
                                    (
                                        [0] => minLength
                                        [1] => 4
                                    )

                            )

                        [Passwords must match] => Array
                            (
                                [rule] => Array
                                    (
                                        [0] => passwordCompare
                                        [1] => password_confirm
                                    )

                            )

                    )

            )

        [useDbConfig] => default
        [useTable] => users
        [displayField] => id
        [id] => 
        [data] => Array
            (
            )

        [table] => users
        [primaryKey] => id
        [_schema] => Array
            (
                [id] => Array
                    (
                        [type] => integer
                        [null] => 
                        [default] => 
                        [length] => 11
                        [key] => primary
                    )

                [type] => Array
                    (
                        [type] => boolean
                        [null] => 
                        [default] => 1
                        [length] => 1
                    )

                [is_active] => Array
                    (
                        [type] => boolean
                        [null] => 
                        [default] => 1
                        [length] => 1
                    )



                [gender] => Array
                    (
                        [type] => boolean
                        [null] => 
                        [default] => 1
                        [length] => 1
                    )

                [first_name] => Array
                    (
                        [type] => string
                        [null] => 
                        [default] => 
                        [length] => 200
                        [collate] => latin1_swedish_ci
                        [charset] => latin1
                    )

                [last_name] => Array
                    (
                        [type] => string
                        [null] => 
                        [default] => 
                        [length] => 200
                        [collate] => latin1_swedish_ci
                        [charset] => latin1
                    )

                [email] => Array
                    (
                        [type] => string
                        [null] => 
                        [default] => 
                        [length] => 200
                        [collate] => latin1_swedish_ci
                        [charset] => latin1
                    )

                [username] => Array
                    (
                        [type] => string
                        [null] => 
                        [default] => 
                        [length] => 200
                        [collate] => latin1_swedish_ci
                        [charset] => latin1
                    )

                [password] => Array
                    (
                        [type] => string
                        [null] => 
                        [default] => 
                        [length] => 200
                        [collate] => latin1_swedish_ci
                        [charset] => latin1
                    )

                [created] => Array
                    (
                        [type] => datetime
                        [null] => 
                        [default] => 
                        [length] => 
                    )

                [modified] => Array
                    (
                        [type] => datetime
                        [null] => 
                        [default] => 
                        [length] => 
                    )

                [bio] => Array
                    (
                        [type] => string
                        [null] => 
                        [default] => 
                        [length] => 2048
                        [collate] => latin1_swedish_ci
                        [charset] => latin1
                    )

            )

        [validationErrors] => Array
            (
            )

        [tablePrefix] => 
        [alias] => User
        [tableToModel] => Array
            (
                [users] => User
            )

        [logTransactions] => 
        [cacheQueries] => 
        [belongsTo] => Array
            (
            )

        [hasOne] => Array
            (
            )

        [hasMany] => Array
            (
            )

        [hasAndBelongsToMany] => Array
            (
            )

        [actsAs] => 
        [Behaviors] => BehaviorCollection Object
            (
                [modelName] => User
                [_attached] => Array
                    (
                    )

                [_disabled] => Array
                    (
                    )

                [__methods] => Array
                    (
                    )

                [__mappedMethods] => Array
                    (
                    )

            )

        [whitelist] => Array
            (
            )

        [cacheSources] => 1
        [findQueryType] => 
        [recursive] => 1
        [order] => 
        [virtualFields] => Array
            (
            )

        [__associationKeys] => Array
            (
                [belongsTo] => Array
                    (
                        [0] => className
                        [1] => foreignKey
                        [2] => conditions
                        [3] => fields
                        [4] => order
                        [5] => counterCache
                    )

                [hasOne] => Array
                    (
                        [0] => className
                        [1] => foreignKey
                        [2] => conditions
                        [3] => fields
                        [4] => order
                        [5] => dependent
                    )

                [hasMany] => Array
                    (
                        [0] => className
                        [1] => foreignKey
                        [2] => conditions
                        [3] => fields
                        [4] => order
                        [5] => limit
                        [6] => offset
                        [7] => dependent
                        [8] => exclusive
                        [9] => finderQuery
                        [10] => counterQuery
                    )

                [hasAndBelongsToMany] => Array
                    (
                        [0] => className
                        [1] => joinTable
                        [2] => with
                        [3] => foreignKey
                        [4] => associationForeignKey
                        [5] => conditions
                        [6] => fields
                        [7] => order
                        [8] => limit
                        [9] => offset
                        [10] => unique
                        [11] => finderQuery
                        [12] => deleteQuery
                        [13] => insertQuery
                    )

            )

        [__associations] => Array
            (
                [0] => belongsTo
                [1] => hasOne
                [2] => hasMany
                [3] => hasAndBelongsToMany
            )

        [__backAssociation] => Array
            (
            )

        [__insertID] => 
        [__numRows] => 
        [__affectedRows] => 
        [_findMethods] => Array
            (
                [all] => 1
                [first] => 1
                [count] => 1
                [neighbors] => 1
                [list] => 1
                [threaded] => 1
            )

        )

    [Child] => Post Object
 *RECURSION*
)

2 个答案:

答案 0 :(得分:2)

你把它放在Children模型中。

var $belongsTo = array( 'Post' );

顺便说一下,你发布的是模型,而不是控制器。希望这只是一个错字,你在正确的地方有。

目前还不清楚你是否称该模特为“儿童”或“儿童”。 $hasMany关系使用Children,但在您说Posts.Child的问题中 - 您是否正确设置了拐点?

编辑:我可能误解了这个问题:如果你想要一个hasMany关系,你已经拥有了。问题在于检索数据的方式或关系定义中的问题。

答案 1 :(得分:1)

你不需要做任何事情,一个孩子也是一个帖子,所以也属于一个用户。 (你应该把它命名为“儿童”而不是“儿童”)

使用可包含的内容,请尝试以下操作:$this->Post->find('all',array('contain'=>array('Child'=>array('User'))));