我使用Cake PHP 2.2.2
我有3张桌子:餐厅,厨房和厨房_餐厅 – 连接HABTM表.

在餐厅里,我有:

public $hasAndBelongsToMany = array(
    'Kitchen' =>
        array(
            'className'              => 'Kitchen','joinTable'              => 'kitchens_restaurants','foreignKey'             => 'restaurant_id','associationForeignKey'  => 'kitchen_id','unique'                 => true,'conditions'             => '','fields'                 => 'kitchen','order'                  => '','limit'                  => '','offset'                 => '',),

问题是我有一个单独的控制器为我的主页面,我需要从复杂的条件从这个模型检索数据.

我补充说

public $uses = array('Restaurant');

到我的主页控制器,这里是我需要你的建议的部分.

我只需要选择那些厨房= $id的餐厅.
我试图添加

public function index() {   
$this->set('rests',$this->Restaurant->find('all',array(
'conditions' => array('Restaurant.active' => "1",'Kitchen.id' => "1")
)));

}

我得到sqlSTATE [42S22]:未找到列:1054’where子句’错误中的未知列.
显然,我需要从“HABTM连接表”中获取数据,但是我不知道如何.

TLDR:

要根据[ HABTM ]协会的条件检索受限制的数据,您需要使用[ Joins ].

说明:

下面的代码遵循[ Fat Model/Skinny Controller ]的咒语,所以逻辑主要都在模型中,只是从控制器调用.

注意:如果您遵循[ CakePHP conventions ](您现在看到的),则不需要所有HABTM参数.

下面的代码还没有被测试(我在这个网站上写过),但它应该是很亲密的,至少让你走向正确的方向.

码:

//餐厅模特

public $hasAndBelongsToMany = array('Kitchen');

/**
 * Returns an array of restaurants based on a kitchen id
 * @param string $kitchenId - the id of a kitchen
 * @return array of restaurants
 */
public function getRestaurantsByKitchenId($kitchenId = null) {
    if(empty($kitchenId)) return false;
    $restaurants = $this->find('all',array(
        'joins' => array(
             array('table' => 'kitchens_restaurants','alias' => 'KitchensRestaurant','type' => 'INNER','conditions' => array(
                    'KitchensRestaurant.kitchen_id' => $kitchenId,'KitchensRestaurant.restaurant_id = Restaurant.id'
                )
            )
        ),'group' => 'Restaurant.id'
    ));
    return $restaurants;
}

//任何控制器

public function whateverAction($kitchenId) {
    $this->loadModel('Restaurant'); //don't need this line if in RestaurantsController
    $restaurants = $this->Restaurant->getRestaurantsByKitchenId($kitchenId);
    $this->set('restaurants',$restaurants);
}

CakePHP如何用条件检索HABTM数据?的更多相关文章

  1. ios – 将核心数据检索到表视图单元格中

    我试图简单地存储和检索CoreData(我以前用swift成功的东西).我的数据没有数据,但现在(不知道是什么改变)我没有得到错误,只是没有显示在表格中.我不知道是否存储或检索对象的问题.我已经跟随我在另一个应用程序中尽可能的做了,但似乎有一些根本的事情,我没有得到.这是我有的我的型号:在我的tableviewcontroller中,静态单元格用于文本字段,我想保存数据:在我的tableviewc

  2. Android sqlite:如何从特定列中检索特定数据?

    我正在开发餐厅菜单应用程序.我的应用程序有一个sqlite表,其中包含以下列:category列的内容是string类型.表的主键是id.我想检索特定类别的数据.例如,我想检索Veg类别中所有项目的项目名称,然后在列表视图中显示该结果.我尝试过不同的查询,但两者都无效.请帮我.原始查询解决方法试试这个:

  3. 在Android上从bundle中检索数据时出现ClassCastException

    我有一些状态,我希望在片段的生命周期中保存.例如,当屏幕旋转时,它工作正常,但是当从磁盘中杀死并恢复进程时(我认为它是如何工作的),我得到一个ClassCastException.这是一些代码:初始化:保存数据:我从onCreate中的强制转换得到的例外:我知道在Android上使用parcelables会更好,但我仍然不明白这是怎么回事.有任何想法吗?解决方法关于类似问题的有趣读物可以在here

  4. android – 如何检索ImageView的ImageUri?

    我期待从ImageView访问当前图像的Uri的方法,将其保存到我的数据库,但我只找到了setter.吸气剂在哪里?解决方法没有吸气剂.由于您是调用setimageURI()的人,因此在调用该方法时将Uri保存到数据库中.请记住,ImageViews并不总是具有Uri,这就是没有getter的原因.

  5. android – 如何设置TI SensorTag以收集数据以供日后检索?

    我正在使用TISensorTag,我希望它能够在手机不在范围内时通过蓝牙LE连接来存储数据.目前,传感器仅在设备处于无线范围内时才传输数据.通过访问SensorTag上的固件,即使手机不在范围内,也可以使其存储数据,然后在设备可用时进行传输.我正在使用iPhone,使用theirexamplecode访问它.我也可以使用Android代码,如果有人认为它会更好用.是否可以告诉固件在本地记录此数据?

  6. android – 如何正确检索将数据插入Google Fit的应用程序的包名?

    我有以下代码用于从GoogleFit检索用户活动列表:要将活动插入GoogleFit,我使用了Google健身应用和Runkeeper(目前,这些应用似乎只是与Fit集成的应用).我的代码按预期检索这些活动,但是,对于每个活动,我的getSourceAppPackageNameFromDataSet()方法返回“com.google.android.gms”作为包名.根据DataAttributi

  7. android – 共享首选项中的数据缓存

    我的应用程序中有2个进程.从一个进程我将数据保存到SharedPreferences.从第二个过程–检索.当我检索数据时,我收到旧数据的SharedPreferences(我检查xml文件并查看,当前文件中的数据和收到的数据不同).看起来这个数据是缓存的.我更改了保存方法(提交/应用)但没有结果.PS:仅举例如http://pastebin.com/Zx2ffvSg解决方法解决方案是在打开共享首选

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

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

  9. 初品cakephp 入门基础

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

  10. 初学CAKEPHP 基础教程

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

随机推荐

  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之组件的注册与创建的实现方法,非常不错,具有参考借鉴价值,需要的朋友可以参考下

返回
顶部