- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
CakePHP Version: 3.1.4
我在模型 Paintings 中有一个自定义查找器,我在其中加入另一个表 Artists 并从两者中选择字段以稍后显示在 View 中:(他们有关系:Paintings belongsTo Artists)
class PaintingsTable extends Table
{
// top five pics
public function findTopfive(Query $query, array $options){
$query
->join([
'artists' =>[
'table' => 'artists',
'type' => 'INNER',
'conditions' => 'Paintings.artist_id = Artists.id'
]
])
->select(['Paintings.id', 'Paintings.title', 'Paintings.ticket_count', 'Artists.name'])
->where(['ticket_count >=' => 1])
->order(['ticket_count' => 'DESC'])
->limit(5);
return $query;
}
然后我在 Controller 中使用查找器:
class CashpositionsController extends AppController
{
public function overview()
{
// TOP 5 paintings:
$paintings = TableRegistry::get('Paintings');
$top_paintings = $paintings->find('topfive');
}
}
我可以像这样显示绘画中的数据:
<?php foreach ($top_paintings as $paintings): ?>
<tr>
<td><?= h($paintings->id); ?> </td>
<td><?= h($paintings->ticket_count); ?> </td>
<td> <!-- here should be paintings->artist->name --> </td>
</tr>
<?php endforeach; ?>
但是如何在此处显示来自连接表的 Artist.name?
数据是从这样的查询中获取的:
->top_paintings(array)
-> 0(object)
id 9
title nicepic
ticket_count 4
artist_id 80
-> Artists(array)
name MrArtist
-> 1(object)
所以数据就在那里,但我就是无法显示它。我尝试了各种语法方法,我在其他文件中成功使用了语法,但我无法弄清楚这个方法。我在 Cookbook 中也找不到这方面的示例,但也许我搜索了错误的地方。
对此正确的语法是什么?
最佳答案
好吧,纯属巧合,我想通了:
问题实际上出在模型内的查询中,我必须在其中为关联数据分配一个字段名称才能在 View 中访问它。我想出来是因为我用预定义的 SQL 函数“count”为另一个模型做了这个例子:
// top five members
public function findTopfive(Query $query, array $options){
$query
->join([
'tickets' =>[
'table' => 'tickets',
'type' => 'INNER',
'conditions' => 'Tickets.member_id = Members.id'
]
])
->join([
'tickets_paintings' => [
'table' => 'tickets_paintings',
'type' => 'LEFT',
'conditions' => ['tickets_paintings.ticket_id = Tickets.id']
]
])
->select([
'Members.id',
'Members.surname',
'Members.ticket_count',
'count' => $query->func()->count('tickets_paintings.painting_id')
])
->where(['ticket_count >=' => 0])
->group('Members.id')
->order(['ticket_count' => 'DESC'])
->limit(5);
return $query;
}
我可以像访问 View 中的其他字段一样访问计数:
<?= h($members->count); ?>
因此,要更正我之前问题中的代码,它必须如下所示:
->select('Paintings.id',....., 'this_artist' => 'Artists.name')
然后在 View 中可以像访问其他字段一样访问该字段:
<?= h($paintings->this_artist); ?>
DebugKit 中显示的查询变量也将如下所示:
->top_paintings(array)
-> 0(object)
id 9
title nicepic
ticket_count 4
artist_id 80
this_artist MrArtist
关于php - CakePHP 3 : Display data from join table used in custom finder,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33972864/
除了 Display.getOrientation() 已弃用之外,Display.getRotation() 和 Display.getOrientation() 之间还有什么区别? 是否都返回等于
我的问题 这些方法中有哪一种是专业网页设计师所偏爱的吗? Web 浏览器在绘制网站时是否首选这些方法中的任何一种? 这只是个人喜好吗? 我还缺少其他技巧吗? 注意:以上问题是关于设计多列布局 floa
我的问题 专业网页设计师是否喜欢这些方法? 网页浏览器在绘制网站时是否首选这些方法? 这只是个人喜好吗? 我还缺少其他技术吗? 注意:以上问题与设计多列布局有关 float :左; http://js
我有一些代码返回 MyTrait 类型的特征对象,这样它就可以返回几个不同结构之一。我想为 trait 对象实现 Display trait,这样我就可以打印对象,并将详细信息委托(delegate)
package polymorphism; /* * @author Rahul Tripathi */ public class OverLoadingTest { /** *
我希望 Display.timerExec(int,Runnable)与 Display.asyncExec(Runnable) 大致相同但有指定的延迟。然而,似乎Display.timerExec只
就像标题所暗示的,有什么区别吗?我当时使用的是pygame.display.flip,我在互联网上看到的是,他们使用pygame.display.update而不是使用flip。哪一个更快? 最佳答案
Sample.this.display() 和 this.display() 哪个更好? class Sample{ void display(){ System.out.println("d
当图像的 CSS 属性“显示”已被任何其他 JS 脚本/函数更改时,我想运行一些 JS 代码。有什么方法可以监视该更改并设置回调函数吗? $(this).bind.('propertychange',
在浏览 Google 字体时我注意到第一个过滤器包含这些类别: Serif Sans 衬线 展示 手写 我知道什么是 (Sans)Serif 和 Handwriting 类别(这很明显)但是显示类别过
我想知道是否可以在列标记内渲染自定义 html,这是显示表标记的一部分。 例如,我希望我的专栏里面有一些下拉列表? 使用纯 html,如下所示: ... Volvo Saab Me
display.newImage() 和 display.newImageRect() 有什么区别? 哪个更好用? 最佳答案 display.newImage() 的文档具体提到: NOTE: dis
我正在使用纯 JS 和 flexbox 为我的元素创建网格。 元素的某些部分在页面加载时被显示隐藏:无,但单击按钮后它应该在不显示和阻止之间切换。 可悲的是,这完全破坏了 display: flex
我目前正在参加 HTML/CSS 类(class),这本书推荐我使用.desktop {display:none;}/.mobile {display:inline;} 以及div class="de
这个问题在这里已经有了答案: Css transition from display none to display block, navigation with subnav [duplicat
我理解 style="display: none" 隐藏一个 HTML 元素,而 style="display: block" 显示一个 block 级 HTML 元素。 我看到一些使用 style=
设置控件的样式 display: none 和 display: block 有什么区别? 最佳答案 display 属性定义了某个 HTML 元素应该如何显示。 Display block 和 no
这个问题已经有答案了: Javascript AND operator within assignment (7 个回答) 已关闭 4 年前。 假设我只想在 this.state.display 为
我不确定如何命名这个问题,因为我是 Rust 新手,所以请随意提出修改建议。 我有两个结构。一个是 Job 结构,其中包含一些数字,例如作业需要多长时间等。另一个是 JobSequence,其中包含
我不确定如何命名这个问题,因为我是 Rust 新手,所以请随意提出修改建议。 我有两个结构。一个是 Job 结构,其中包含一些数字,例如作业需要多长时间等。另一个是 JobSequence,其中包含
我是一名优秀的程序员,十分优秀!