我在Cake PHP的find()方法和“更深层次”模型关联中的条件有一些问题.有一些这些,但到目前为止我找不到答案.

我的模型协会是用户已经有很多帖子已经有很多评论已经有很多投票和投票属于评论belongsTo Post的属于用户分别. belongsTo关联使用内部连接(‘type’=>’INNER’).

如何使用CakePHP的model-> find()方法查找特定用户的所有评论投票?

我故意使用了四个模型的链,因为这似乎适用于直接相关模型的条件.所以没有在邻居表中使用外键保持列(条件’Post.user_id == 1’而不是User.id == 1).

在sql中,这将是:

SELECT v.* 
FROM Votes v 
    JOIN comments c ON (v.comment_id = c.id)
    JOIN posts p ON (c.post_id = p.id)
    JOIN users u ON (p.user_id = u.id)
WHERE u.id = 1

我无法使用find()的可容纳的行为来重现这些连接.虽然我可以简单地获取一个用户的所有数据,然后我将收集所有投票从结果数组内.

它不是这样工作(警告:未知列’User.id’):

$this->Vote->recursive = 2; // or higher
$this->Vote->find('all',array('conditions' => array('User.id' => 1)));

事实上,一旦添加条件,这甚至不会使用Post而不是User(Vote-> Comment-> Post).制造的SQL查询仅加入投票和评论.

返回的数组应该仅包含上面的SQL查询将返回的投票,其他所有内容应该在进程中“加入”.

注意:我的问题非常接近这个,这帮助我开始:
In cakephp how can I do a find with conditions on a related field?

$joins = array(
           array('table'=>'comments','alias' => 'Comment','type'=>'inner','conditions'=> array(
                 'Comment.id = Vote.comment_id'
           )),array('table'=>'posts','alias' => 'Post','conditions'=> array(
                 'Post.id = Comment.post_id'
           )),array('table'=>'users','alias' => 'User','conditions'=> array(
                 'User.id = Post.user_id','User.id'=>$user_id
           ))
         );

$Votes = $this->Vote->find('all',array('joins'=>$joins,'recursive'=>-1));

使用Model-> find()(CakePHP)的相关模型中的条件的更多相关文章

  1. PHP中CakePHP添加数据库实例方法

    在本篇文章里小编给大家整理的一篇关于PHP中CakePHP添加数据库实例方法,对此有兴趣的朋友们可以学习下。

  2. 初品cakephp 入门基础

    近段时间项目挺轻松的,刚好有时间来了解一下cakephp。下面只是一己之见,初识cakephp而已,完全不保证内容的正确性

  3. 初学CAKEPHP 基础教程

    哈!很久没进来过了!今天又重新敲着键盘!把字打进我的BLOG!目的是计下我新学的内容!今天是看CAKEPHP教程的第一天!看完之后!也该写点什么!

  4. cakephp常见知识点汇总

    这篇文章主要介绍了cakephp常见知识点,汇总整理了cakephp的模板、数据库、日志、表单等相关操作技巧,需要的朋友可以参考下

  5. CakePHP的安装的简单方法

    在本篇文章里小编给大家整理的是一篇关于CakePHP的安装的简单方法,对此有兴趣的朋友们可以参考学习下。

  6. cakephp2.X多表联合查询join及使用分页查询的方法

    这篇文章主要介绍了cakephp2.X多表联合查询join及使用分页查询的方法,结合实例形式简单分析了cakephp查询及分页操作相关技巧,需要的朋友可以参考下

  7. CakePHP框架Session设置方法分析

    这篇文章主要介绍了CakePHP框架Session设置方法,结合具体实例形式分析了CakePHP常见的Session操作技巧及相关注意事项,需要的朋友可以参考下

  8. CakephpCakeDC用户使用扩展控制器登录问题

    我想将CakeDC用户插件添加到我的项目中,但我想扩展控制器,因为我需要更改某些操作的布局。当我扩展控制器并尝试登录时,收到以下错误。我已经尝试过所有用插件文档编写的东西,但都不起作用。在此处输入图像描述

  9. 在Ubuntu 10.4中运行CakePHP时面临文件权限错误

    我已经使用以下步骤安装了CakePHP2.0框架:更改tmp文件夹permisssion启用mod-rewrite打开文件/etc/apache2/sites-enabled/000-default并将AllowOverrideNone更改为AllowOverrideAll重新启动Apache我打开浏览器并键入地址http://localhost/cakephp/,并且我删除了这个错误信息:War

  10. CakePHP分页:我如何按多列排序以实现“粘性”功能?

    CakePHPIRC频道上的用户ten1帮我找到了解决方案.我告诉他,如果他在这里发布了答案,那么我会将其标记为正确答案,但他说我应该自己做,因为他还没有StackOverflow帐户.诀窍是使用模型的“beforeFind”回调方法将“粘性”字段注入查询的“顺序”设置,如下所示:

随机推荐

  1. PHP个人网站架设连环讲(一)

    先下一个OmnihttpdProffesinalV2.06,装上就有PHP4beta3可以用了。PHP4给我们带来一个简单的方法,就是使用SESSION(会话)级变量。但是如果不是PHP4又该怎么办?我们可以假设某人在15分钟以内对你的网页的请求都不属于一个新的人次,这样你可以做个计数的过程存在INC里,在每一个页面引用,访客第一次进入时将访问时间送到cookie里。以后每个页面被访问时都检查cookie上次访问时间值。

  2. PHP函数学习之PHP函数点评

    PHP函数使用说明,应用举例,精简点评,希望对您学习php有所帮助

  3. ecshop2.7.3 在php5.4下的各种错误问题处理

    将方法内的函数,分拆为2个部分。这个和gd库没有一点关系,是ecshop程序的问题。会出现这种问题,不外乎就是当前会员的session或者程序对cookie的处理存在漏洞。进过本地测试,includes\modules\integrates\ecshop.php这个整合自身会员的类中没有重写integrate.php中的check_cookie()方法导致,验证cookie时返回的username为空,丢失了登录状态,在ecshop.php中重写了此方法就可以了。把他加到ecshop.php的最后面去就可

  4. NT IIS下用ODBC连接数据库

    $connection=intodbc_connect建立数据库连接,$query_string="查询记录的条件"如:$query_string="select*fromtable"用$cur=intodbc_exec检索数据库,将记录集放入$cur变量中。再用while{$var1=odbc_result;$var2=odbc_result;...}读取odbc_exec()返回的数据集$cur。最后是odbc_close关闭数据库的连接。odbc_result()函数是取当前记录的指定字段值。

  5. PHP使用JpGraph绘制折线图操作示例【附源码下载】

    这篇文章主要介绍了PHP使用JpGraph绘制折线图操作,结合实例形式分析了php使用JpGraph的相关操作技巧与注意事项,并附带源码供读者下载参考,需要的朋友可以参考下

  6. zen_cart实现支付前生成订单的方法

    这篇文章主要介绍了zen_cart实现支付前生成订单的方法,结合实例形式详细分析了zen_cart支付前生成订单的具体步骤与相关实现技巧,需要的朋友可以参考下

  7. Thinkphp5框架实现获取数据库数据到视图的方法

    这篇文章主要介绍了Thinkphp5框架实现获取数据库数据到视图的方法,涉及thinkPHP5数据库配置、读取、模型操作及视图调用相关操作技巧,需要的朋友可以参考下

  8. PHP+jquery+CSS制作头像登录窗(仿QQ登陆)

    本篇文章介绍了PHP结合jQ和CSS制作头像登录窗(仿QQ登陆),实现了类似QQ的登陆界面,很有参考价值,有需要的朋友可以了解一下。

  9. 基于win2003虚拟机中apache服务器的访问

    下面小编就为大家带来一篇基于win2003虚拟机中apache服务器的访问。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  10. Yii2中组件的注册与创建方法

    这篇文章主要介绍了Yii2之组件的注册与创建的实现方法,非常不错,具有参考借鉴价值,需要的朋友可以参考下

返回
顶部