Как разрешить повторяющиеся записи в таблице администратора


Я хочу показать повторяющиеся записи в таблице администратора. эта сетка создается путем объединения таблиц. Если какая-либо повторяющаяся запись из моей пользовательской таблицы, Grid возвращает ошибку, как показано ниже,

Элемент (Magento\Framework\Представление\Элемент\UIComponent\Поставщик данных\Документ) с тем же идентификатором "1" уже существует.

Как отключить эту регистрацию повторяющихся записей grid/collection.php Мой Collection.php находится ниже,

<?php


namespace Webkul\Pos\Model\ResourceModel\Delivery\Grid;
use Psr\Log\LoggerInterface;
use Magento\Framework\ObjectManagerInterface;
use Magento\Framework\Event\ManagerInterface;
use Magento\Store\Model\StoreManagerInterface;
use Magento\Framework\Search\AggregationInterface;
use Magento\Framework\Api\Search\SearchResultInterface;
use Magento\Framework\Data\Collection\EntityFactoryInterface;
use Magento\Framework\Data\Collection\Db\FetchStrategyInterface;
use Webkul\Pos\Model\ResourceModel\Delivery\Collection as DeliveryCollection;

class Collection extends DeliveryCollection implements SearchResultInterface  {

    protected $_aggregations;
    protected $_objectManager;

    public function __construct(
        EntityFactoryInterface $entityFactory,
        LoggerInterface $logger,
        FetchStrategyInterface $fetchStrategy,
        ManagerInterface $eventManager,
        StoreManagerInterface $storeManager,
        ObjectManagerInterface $objectManager,
        $mainTable,
        $eventPrefix,
        $eventObject,
        $resourceModel,
        $connection = null,
        \Magento\Framework\Model\ResourceModel\Db\AbstractDb $resource = null,
        $model = "Magento\Framework\View\Element\UiComponent\DataProvider\Document"
    )  {
        $this->_objectManager = $objectManager;
        parent::__construct(
            $entityFactory,
            $logger,
            $fetchStrategy,
            $eventManager,
            $connection,
            $resource
        );
        $this->_eventPrefix = $eventPrefix;
        $this->_eventObject = $eventObject;
        $this->_init($model, $resourceModel);
        $this->setMainTable($mainTable);
    }



    public function getAggregations()  {
        return $this->_aggregations;
    }

    public function setAggregations($aggregations)  {
        $this->_aggregations = $aggregations;
    }

    public function getSearchCriteria()  {
        return null;
    }

    public function setSearchCriteria(\Magento\Framework\Api\SearchCriteriaInterface $searchCriteria = null)  {
        return $this;
    }

    public function getTotalCount()  {
        return $this->getSize();
    }

    public function setTotalCount($totalCount)  {
        return $this;
    }

    public function setItems(array $items = null)  {
        return $this;
    }

}

Моя модель\Модель ресурсов\Доставка Collectio.php находится ниже,

<?php
 namespace Webkul\Pos\Model\ResourceModel\Delivery;

use 
Magento\Framework\Model\ResourceModel\Db\Collection\AbstractCollection;

class Collection extends AbstractCollection  {

    protected $_idFieldName = "order_id";

    protected function _construct()  {
        $this->_init("Webkul\Pos\Model\Delivery", "Webkul\Pos\Model\ResourceModel\Delivery");


    }

    protected function _initSelect()
    {
      parent::_initSelect();
      $this->getSelect()->join(
            ['secondTable'=>$this->getTable('sales_order_address')],
            'main_table.order_id = secondTable.entity_id','*');
      $this->getSelect()->join(
            ['thirdTable'=>$this->getTable('sales_order_grid')],
            'main_table.order_id = thirdTable.entity_id', '*');

      }

    public function setDeliveryData($condition, $attributeData)  {
        return $this->getConnection()->update($this->getTable("pos_delivery"), $attributeData, $where = $condition);
    }

}

Кто-нибудь, пожалуйста, помогите мне.. Заранее благодарю

Author: Ask Bytes, 2018-10-10

1 answers

Пожалуйста, измените

Защищенное имя поля $_ID = "идентификатор заказа";

С

Защищенный $_idfieldname= "идентификатор"

Потому что первичный ключ ваших пользовательских таблиц - id, а не order_id

 3
Author: Rutvee Sojitra, 2018-10-10 11:50:23