Cakephp多表关联的从表查询笔记

不可否认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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值