- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试复制此有效的 SQL 查询结果:
SELECT r.id, r.day, s.ddbroute_id, s.delivery_id, d.id, d.laststatusid, t.id, t.delivery_id, t.statusstage_id, st.id, st.stage
FROM ddbroutes r
LEFT JOIN ddbrouteslots s on r.id = s.ddbroute_id
LEFT JOIN deliveries d on s.delivery_id = d.id
LEFT JOIN trackingstatuses t on d.laststatusid = t.id
LEFT JOIN statusstages st on t.statusstage_id = st.id
我正在使用 CakePHP 2 模型
第二层以外的底部表格没有公共(public)字段。错误消息是:“模型“Ddbroute”与模型“Delivery”不关联。”因此,我在“包含”数组中尝试了带或不带 Delivery 的情况,两种方式都没有引入 Delivery 字段。如果合适的话,我很乐意使用联接。我已阅读了 StackOverflow 上我能找到的最相关的帖子。
我的代码和更多信息如下。非常感谢任何帮助。
<小时/>我有五个表(包括以下字段):
ddbroutes (id, day)
ddbrouteslots (id, ddbroute_id, delivery_id)
deliveries (id, laststatusid)
trackingstatuses (id, statusstage_id)
statusstages (id, stage)
模型中设置了以下关系:
Ddbroute hasMany Ddbrouteslot (Ddbrouteslot belongsTo Ddbroute)
Delivery hasOne Ddbrouteslot (Ddbrouteslot belongsTo Delivery)
Delivery hasMany Trackingstatus (Trackingstatus belongsTo Delivery)
Statusstage hasMany Trackingstatus (Trackingstatus belongsTo Statusstage)
尽管 Delivery hasOne Ddbrouteslot(这将是 hasMany - 修订版 - 现在仍保留为 hasOne),但对于任何单个 Ddbroute,只有一个与每个 Ddbrouteslot 关联的 Delivery。所有模型均设置了 Containable。我不知道是否需要先使用 unbindModel(它没有更改错误消息)。
我在 Ddbroute.php 模型文件中的代码(仅限交付表)
public $findMethods = array('ddbstatuses' => true);
protected function _findDdbstatuses($state, $query, $results = array()) {
if ($state === 'before') {
$ddbrouteslotmodel = ClassRegistry::init('Ddbrouteslot');
$ddbrouteslotmodel->unbindModel(
array('belongsTo' => array('Delivery'))
);
$ddbrouteslotmodel->bindModel(
array('hasOne' => array(
'Delivery' => array(
'className' => 'Delivery',
'foreignKey' => 'id',
'dependent' => false,
'fields' => array(
'id', 'laststatusid'
)
)
))
);
$deliverymodel = ClassRegistry::init('Delivery');
$deliverymodel->unbindModel(
array('hasOne' => array('Ddbrouteslot'))
);
$deliverymodel->bindModel(
array('belongsTo' => array(
'Delivery' => array(
'className' => 'Delivery',
'foreignKey' => 'delivery_id'
)
)
)
);
$query['contain'] = array(
'Ddbrouteslot', 'Delivery'
);
return $query;
}
return $results;
}
在另一个 Controller 中,运行查找操作:
$this->LoadModel('Ddbroute');
$ddbstatuses = $this->Ddbroute->find('ddbstatuses');
$this->set(compact('ddbstatuses')); // to make available in a view
我还进一步尝试使用长连接数组,但查询没有引入任何 Delivery、Trackingstatus 或 Statusstage 信息,尽管查询似乎已运行。
public $findMethods = array('ddbstatuses' => true);
protected function _findDdbstatuses($state, $query, $results = array()) {
if ($state === 'before') {
ClassRegistry::init('Delivery'); // not sure these three lines were needed so I tried with and without them
ClassRegistry::init('Trackingstatus');
ClassRegistry::init('Statusstage');
$query['joins'] = array(
array(
'table' => 'ddbrouteslots',
'alias' => 'Ddbrouteslot',
'type' => 'LEFT',
'conditions' => array(
'Ddbroute.id = Ddbrouteslot.ddbroute_id'
)),
array(
'table' => 'deliveries',
'alias' => 'Delivery',
'type' => 'LEFT',
'conditions' => array(
'Ddbrouteslot.id = Delivery.id'
)),
array(
'table' => 'trackingstatuses',
'alias' => 'Trackingstatus',
'type' => 'LEFT',
'conditions' => array(
'Delivery.laststatusid = Trackingstatus.id'
)),
array(
'table' => 'statusstages',
'alias' => 'Statusstage',
'type' => 'LEFT',
'conditions' => array(
'Trackingstatus.statusstage_id = Statusstage.id'
))
);
$query['contain'] = array(
'Ddbrouteslot',
'Delivery', // Not sure I should be adding these other models, so I tried with and without them
'Trackingstatus',
'Statusstage'
);
return $query;
}
return $results;
}
最佳答案
经过一些帮助,我现在有四种解决方案来获取我的数据,尽管实际上其中三个是第一个解决方案的变体。我相对缺乏经验,有些基本的东西我不太欣赏。
<强>1。在 Controller 中
$this->LoadModel("Ddbrouteslot");
$res = $this->Ddbrouteslot->find("all", array(
"conditions" => array(
"Ddbrouteslot.delivery_id > 0",
"Ddbrouteslot.ddbroute_id" => 45
),
"contain" => array(
"Ddbroute",
"Delivery" => array(
"Trackingstatus" => array(
"order" => array(
"Trackingstatus.id" => "desc"
),
"limit" => 1,
"Statusstage"
)
)
)
);
来自 DebugKit 的计时:主查询为 20 毫秒; Trackingstatus 和 Statusstage 是针对四个相关交付的额外查询,每次 18 毫秒 x 4;总时间为 164 毫秒。这非常慢,并不理想。
这要从第二个模型 Ddbrouteslot 开始,因为它与 Ddbroute 和 Delivery 都有直接关系。任何协会均未发生任何变化。从 Ddbrouteslot 到 Delivery 的 ownTo 关系工作正常。Delivery_id 上的 Delivery 和 Trackingstatus 之间已经存在 hasMany 关系。
<小时/><强>2。使用 SQL
$this->LoadModel("Ddbroute");
$qres = $this->Ddbroute->query(
"SELECT *
FROM
ddbroutes AS r
LEFT JOIN ddbrouteslots s on r.id = s.ddbroute_id
LEFT JOIN deliveries d on s.delivery_id = d.id
LEFT JOIN trackingstatuses t on d.laststatusid = t.id
LEFT JOIN statusstages st on t.statusstage_id = st.id
WHERE s.delivery_id > 0 AND s.ddbroute_id = 45
;"
debug($qres);
时间:这花了 19 毫秒。这意味着速度要快得多。 Cake 文档中不建议这样做,并且显然它不像纯 Cake find 那样在数据库之间可移植。
<小时/><强>3。更改基本模型
$rres = $this->Ddbroute->find("all", array(
"conditions" => array(
"Ddbroute.id" => 45
),
"recursive" => -1,
"contain" => array(
"Ddbrouteslot" => array(
"conditions" => array(
"Ddbrouteslot.delivery_id > 0"
),
"Delivery" => array(
"Trackingstatus" => array(
"order" => array(
"Trackingstatus.id" => "desc"
),
"limit" => 1,
"Statusstage"
)
)
)
)
));
debug($rres);
计时:主查询为 18 毫秒;对于四个相关的交付,Delivery、Trackingstatus 和 Statusstage 均为 18ms x 4;总时间为 234 毫秒。它速度较慢,因为每次发货都需要运行 Delivery,因为它不在 Ddbroute 的模型内。改变递归并没有什么区别。
<小时/><强>4。使用自定义查找这与上面的 1.) 是相同的查询,但只是使用了自定义查找方法。
public $findMethods = array('ddbstatuses' => true);
protected function _findDdbstatuses($state, $query, $results = array()) {
if ($state === 'before') {
$query['conditions'] = array(
"Ddbrouteslot.delivery_id > 0",
"Ddbrouteslot.ddbroute_id" => 45
);
$query['contain'] = array(
"Ddbroute",
"Delivery"=> array(
"Trackingstatus" => array(
"order" => array(
"Trackingstatus.id" => "desc"
),
"limit" => 1,
"Statusstage"
)
)
);
return $query;
}
return $results;
}
关于php - 如何使用 bindModel 和自定义查找器将 CakePHP 2 模型关联更改为深度链接?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41412754/
经验丰富的程序员,但对 CakePHP 2.1 不熟悉,我花了一天的时间努力让自定义 Helper 在 View 中工作,遵循手册:http://book.cakephp.org/2.0/en/vie
任何人都可以列出 CakePHP 框架相对于其他 PHP 框架的缺点吗? 1) 请解释为什么缺少的功能对 PHP 项目如此重要? 2) 该缺失的功能如何帮助那些使用具有该功能的框架的 Web 开发人员
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 6年前关闭。 Improve thi
我对 PHP 比较陌生。开始学习 PHP,但后来遇到了 cakePHP,它可以加快开发时间。 阅读文档和博客教程后,我仍然不明白命名约定。我想在我开始做一些例子之前我不会知道,但是为了让我开始,有人可
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 6 年前。
任何人都可以告诉我为什么当一个字段没有翻译时它返回空,而不是默认翻译? 我会感谢所有建议... 不知道你想看我代码的哪一部分,因为它都是直接来自 www.book.cake.org。所以我粘贴了一些代
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引起辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the he
我正在编写一个支持多种测量单位的应用程序。在极少数情况下,用户想要更改他们的测量系统,我需要运行一个查询,该查询应用乘数将应用程序中的每个单位列缩放到正确的测量系统。为了确保所有数据在此操作出现问题时
很难说出这里问的是什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或言辞激烈,无法以目前的形式合理回答。如需帮助澄清此问题以便可以重新打开,visit the help center . 8年前关闭
在用户模型中: var $hasMany = array( 'Photo' => array( 'className' => 'Photo',
剧透:我想更好地了解对 CakePHP 应用程序的请求的生命周期。 背景:我使用的是 CakePHP v2.3。我正在调试一个问题,该问题导致我无法找到的不想要的重定向。我正在尝试通过增量添加 die
在我的 Cake 应用程序中,我有一个 Controller “completed_projects”。它的索引操作不带参数并列出了一些项目。可以访问不同的页面example.com/complete
我找不到有关cakeError()定义为成员函数的任何信息。 documentation仅声明该调用看起来像这样: $this->cakeError(string $errorType [, arra
我创建了一个自定义数据源,该数据源从Web api获取数据,现在我正在研究实现错误处理。 在数据源中,我正在调用$ model-> onError()。在模型中,我创建了onError方法,并且可以使
除了重定向和渲染之外,还有其他命令可以将 Controller 重定向到特定 View 页面吗? 我的重定向为 $this->redirect('/forms/homepage/'.$userId);
我试图在我的字段中查找计数并连接该计数,但它给出错误消息,因为找不到 make_count 并且我在上面创建了相同的字段。 $this->Car->virtualFields['make_count'
我想要条件验证,即在更新密码时隐藏字段,并且密码验证为“6 到 15”个字符!因此密码以哈希格式存储在数据库中,因此不允许我更新。我的模型代码如下, array( 'rule
echo $form->input( 'country_id', array( 'type' => 'select', 'label' => __('C
我正在使用 CakePHP 创建一个锦标赛平台。目前,我已经创建了以下可以完美运行的表格、模型和 Controller :锦标赛、用户和团队。 我还创建了一个“Tournamentuser”表、 Co
我的场景是这样的: 在我的/views/layout/default.ctp 在我的/views/pages/home.ctp Html-
我是一名优秀的程序员,十分优秀!