【问题标题】:show field_name from joined table instead of field_id in yajra datatables that generated from infyom在从 infyom 生成的 yajra 数据表中显示来自连接表的 field_name 而不是 field_id
【发布时间】:2018-11-28 02:25:45
【问题描述】:

我有

  • 带有字段“id”、“transaction_id”、“date”、“amount”、“payment_method_id”、“additional_note”的付款数据表
  • payment_methods 表包含字段“id”、“name”、“code”

我想要实现的是在支付数据表中显示 payment_method->name 而不是 payment_method_id

这是我的数据表代码

 <?php

namespace App\DataTables;

use App\Models\Payment;
use Yajra\DataTables\Services\DataTable;
use Yajra\DataTables\EloquentDataTable;

class PaymentDataTable extends DataTable
{
    /**
     * Build DataTable class.
     *
     * @param mixed $query Results from query() method.
     * @return \Yajra\DataTables\DataTableAbstract
     */
    public function dataTable($query)
    {
        $dataTable = new EloquentDataTable($query);

        return $dataTable->addColumn('action', 'payments.datatables_actions');
    }

    /**
     * Get query source of dataTable.
     *
     * @param \App\Models\Post $model
     * @return \Illuminate\Database\Eloquent\Builder
     */
    public function query(Payment $model)
    {
        return $model->newQuery();
    }

    /**
     * Optional method if you want to use html builder.
     *
     * @return \Yajra\DataTables\Html\Builder
     */
    public function html()
    {
        return $this->builder()
            ->columns($this->getColumns())
            ->minifiedAjax()
            ->addAction(['width' => '120px'])
            ->parameters([
                'dom'     => 'Bfrtip',
                'order'   => [[0, 'desc']],
                'buttons' => [
                    ['extend' => 'create', 'className' => 'btn btn-default btn-sm no-corner',],
                    ['extend' => 'export', 'className' => 'btn btn-default btn-sm no-corner',],
                    ['extend' => 'print', 'className' => 'btn btn-default btn-sm no-corner',],
                    ['extend' => 'reset', 'className' => 'btn btn-default btn-sm no-corner',],
                    ['extend' => 'reload', 'className' => 'btn btn-default btn-sm no-corner',],
                ],
            ]);
    }

    /**
     * Get columns.
     *
     * @return array
     */
    protected function getColumns()
    {
        return [
            'transaction_id',
            'date',
            'amount',
            'payment_method_id',
            'additional_note'
        ];
    }

    /**
     * Get filename for export.
     *
     * @return string
     */
    protected function filename()
    {
        return 'paymentsdatatable_' . time();
    }
}

我四处搜索并知道它必须在

中做一些事情
 public function query(Payment $model)
        {
            return $model->newQuery();
        }

但还没有找到有效的解决方案..也许有什么建议

nb:我也在这里发帖问过这个问题https://github.com/InfyOmLabs/laravel-generator/issues/582,但还没有回复

【问题讨论】:

标签: laravel datatable yajra-datatable


【解决方案1】:

使用 InfyOm Laravel Generator 将关系数据显示到 Yajra 数据表中

需要在你的数据表文件上修改 getColumn() 方法。

protected function getColumns()
{
    return [
        'title',
        'author_name' => new \Yajra\DataTables\Html\Column(['title' => 'Author Name', 'data' => 'author.name', 'name' => 'author.name'])
    ];
} 

并修改query方法返回关系数据

public function query(Post $model)
{
    return $model->newQuery()->with(['author']);
}

这里有完整的博客示例:https://blog.infyom.com/how-to-display-relationship-data-into-yajra-datatables-with-infyom-laravel-generator

【讨论】:

    【解决方案2】:

    有一段时间没有使用 Yajra 表了,但我做了类似的事情。根据您命名PaymentPaymentMethod 之间关系的方式,根据您的情况进行修改。

    public function query(Payment $model)
    {
        return $model->newQuery()->with(['paymentMethod']);
    
        // specify columns if you like
        // return $model->newQuery()->with(['paymentMethod'])->select('payments.*');
    }
    
    ...
    
    protected function getColumns()
    {
        return [
            'transaction_id',
            'date',
            'amount',
            [
                'name' => 'paymentMethod.name',
                'data' => 'paymentMethod.name',
                'title' => 'Payment Method',
                'defaultContent' => '',
            ],
            'additional_note',
        ];
    }
    

    【讨论】:

    • return $model->newQuery()->with(['paymentMethod']); “paymentMethod”应该是型号名称?或参考什么?
    • 至于如何获取列似乎是真的写了..我已经完成了我的搜索并得到了同样的结果,但是如何进行查询是我坚持的问题
    • 当我尝试它时..它仍然给我的 payment_method.name 空白
    • @user2180614 paymentMethod 是在 Payment 模型上定义的方法,用于返回与 PaymentMethod 模型的关系。你们是如何建立这种关系的?
    • 嗯我这样定义它 public function paymentmethod() { return $this->belongsTo('App\Models\PaymentMethod','payment_method_id'); } 并且没有错误但没有显示 payment_method.name
    猜你喜欢
    • 2021-10-12
    • 2021-09-04
    • 2017-04-21
    • 1970-01-01
    • 1970-01-01
    • 2022-11-01
    • 2021-05-13
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多