不可否认Cakephp对于查询的封装是有限制的,但是通过利用Cakephp的语法规则,可以很好的弥补这一点。 我们在应用中遇到的问题: {查询Note的ID小于10的所有User,User表和Note表是一对多关联} 我们通常的做法是 $users = $this->User->find('all',array( 'conditions' => array( 'Note.id <' => 10 ) )); 注意:这种做法是错误的。 原因是: Cakephp对于hasMany的关联,会生成下列的语句 SELECT `User`.`id`, `User`.`name`, `User`.`username`, `User`.`password`, `User`.`created` FROM `users` AS `User` WHERE `Note`.`id` < 10 可以看到,Note表并没有被Join到查询中,所以,MySql会提示 Unknown column 'Note.id' in 'where clause' 我们应该怎样查询条件从属于关联表的记录呢? 简单介绍一下Cakephp的四种关联模式对应的从属关联条件的方法。 1. 最简单的hasOne和belongsTo关联 这类的关联我们可以直接写关联表的条件,而不会出现Unknow column的错误。 2. 稍稍复杂的hasMany关联(一对多关联) 就像你在上面看见的,hasMany关联是不能直接实现上述的查询条件的,但是我们可以变通一下,我们可以把hasMany关联查询转换为belongsTo关联查询,按照上面的条件,我们再试一试 $users = $this->User->Note->find('all',array( 'conditions' => array( 'Note.id <' => 10 ), 'contain' => array('User'), 'fields' => array( 'Note.id', 'User.id', 'User.name' ) )); 这次得到的结果类似于下面的数据 Array ( [0] => Array ( [...]
转载于:https://my.oschina.net/thinkly/blog/662