不能否认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 ( [...]