How to get the default core write and read resources in Magento 2
Since Magento 2 relies on the concept of resources to interact with database, you can easily get the global resource and use it for playing with SQL queries or execute directly.
data:image/s3,"s3://crabby-images/10db4/10db4a15e9125ad6b84ff1943ee934b101695344" alt=""
In order to achieve this goal, you have to inject the object resource Magento\Framework\App\Resource inside di.xml.
In the following example, we use a custom action of the MassDelete controller:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 |
<config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="../../../../../../lib/internal/Magento/Framework/ObjectManager/etc/config.xsd"> <type name="Ibnab\DeleteOrders\Controller\Adminhtml\Order\MassDelete"> <arguments> <argument name="deleteorderAction" xsi:type="array"> <item name="context" xsi:type="string">Magento\Backend\App\Action\Context</item> <item name="resource" xsi:type="string">Magento\Framework\App\Resource</item> </argument> </arguments> </type> </config> |
Now, get the resource and put it to the class variable inside the action:
1 2 3 4 5 6 7 8 9 10 11 12 13 |
protected _resource; public function __construct(Context $context, \Magento\Framework\App\Resource $resource) { $this->_resource = $resource; parent::__construct($context); } |
Get a stream or resource for reading / writing :
1 2 3 4 5 |
$connectionReader = $this->_resource->getConnection(\Magento\Framework\App\Resource::DEFAULT_READ_RESOURCE); $connectionWriter = $this->_resource->getConnection(\Magento\Framework\App\Resource::DEFAULT_WRITE_RESOURCE); $showTables = $connectionWriter->fetchCol('show tables'); |
Now:
- get the name of a table that concat the prefix
1 |
$tblSalesOrder = $connectionReader->getTableName('sales_order'); |
- fetch a use select statement
1 |
$result1 = $connectionWriter->fetchAll('SELECT quote_id FROM `'.$tblSalesOrder.'` WHERE entity_id='.$orderId); |
or a custom query:
1 |
$connectionWriter->rawQuery('DELETE FROM `'.$tblSalesCreditmemoGrid.'` WHERE order_id='.$orderId); |
More tips from Magento 2 Developer’s Cookbook
data:image/s3,"s3://crabby-images/10db4/10db4a15e9125ad6b84ff1943ee934b101695344" alt=""