gpt4 book ai didi

php - CakePHP 3 : Display data from join table used in custom finder

转载 作者:行者123 更新时间:2023-11-29 03:27:45 25 4
gpt4 key购买 nike

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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com