Magento2 in we have collection of order, product, customer etc. For some bussiness logic we need filter collection with difeerent conditions to get data. In this blog we can see different type of condition for addAttributeToFilter and addFieldToFilter in magento2.
We can use addAttributeToFilter and addFieldToFilter we below conditions.
Here simple code of load product collection with addAttributeToFilter.
/** @var \Magento\Catalog\Model\ResourceModel\Product\CollectionFactory $productCollectionFactory */
$collection = $this->productCollectionFactory->create();
$collection->addAttributeToFilter('sku', 'ABC');
Here mention all condition with sample code.
Table of Contents [hide]
- 1 Equal Value (eq)
- 2 Not Equal Value (neq)
- 3 Like Value (like)
- 4 From Value to To Value (from, to)
- 5 In Values (in)
- 6 Not In Values (nin)
- 7 Value Is NotNull (notnull)
- 8 Value Is Null (null)
- 9 Greater Value (gt)
- 10 Less Value (lt)
- 11 Greater Or Equal Value (gteq)
- 12 Less Or Equal Value (lteq)
- 13 Value In Set (finset)
- 14 Value Not In Set (nfinset)
- 15 Regular Expression (regexp)
Equal Value (eq)
$collection->addAttributeToFilter('sku', 'ABC');
#OR
$collection->addAttributeToFilter('sku', ['eq' => 'ABC']);
# similar you can do with addFieldToFilter
$collection->addFieldToFilter('sku', 'ABC');
#OR
$collection->addFieldToFilter('sku', ['eq' => 'ABC']);
Not Equal Value (neq)
$collection->addAttributeToFilter('sku', ['neq' => 'ABC']);
# similar you can do with addFieldToFilter
$collection->addFieldToFilter('sku', ['neq' => 'ABC']);
Like Value (like)
$collection->addAttributeToFilter('sku', ['like' => '%ABC%']);
# similar you can do with addFieldToFilter
$collection->addFieldToFilter('sku', ['like' => '%ABC%']);
From Value to To Value (from, to)
$collection->addAttributeToFilter('size', ['from' => 35]); # INT type
$collection->addAttributeToFilter('created_at', ['from' => $date, 'date' => true]);
$collection->addAttributeToFilter('created_at', ['to' => $date, 'date' => true]);
$collection->addAttributeToFilter('created_at', ['from' => $date, 'to' => $date];
# similar you can do with addFieldToFilter
$collection->addFieldToFilter('size', ['from' => 35]); # INT type
$collection->addFieldToFilter('created_at', ['from' => $date, 'date' => true]);
$collection->addFieldToFilter('created_at', ['to' => $date, 'date' => true]);
$collection->addFieldToFilter('created_at', ['from' => $date, 'to' => $date];
In Values (in)
$collection->addAttributeToFilter('entity_id', ['in' => [1,2,3]]);
# similar you can do with addFieldToFilter
$collection->addFieldToFilter('entity_id', ['in' => [1,2,3]]);
Not In Values (nin)
$collection->addAttributeToFilter('entity_id', ['nin' => [1,2,3]]);
# similar you can do with addFieldToFilter
$collection->addFieldToFilter('entity_id', ['nin' => [1,2,3]]);
Value Is NotNull (notnull)
$collection->addAttributeToFilter('size', ['notnull' => true]);
# similar you can do with addFieldToFilter
$collection->addFieldToFilter('size', ['notnull' => true]);
Value Is Null (null)
$collection->addAttributeToFilter('size', ['null' => true]);
# similar you can do with addFieldToFilter
$collection->addFieldToFilter('size', ['null' => true]);
Greater Value (gt)
$collection->addAttributeToFilter('level', ['gt' => 1]);
# similar you can do with addFieldToFilter
$collection->addFieldToFilter('level', ['gt' => 1]);
Less Value (lt)
$collection->addAttributeToFilter('level', ['lt' => 1]);
# similar you can do with addFieldToFilter
$collection->addFieldToFilter('level', ['lt' => 1]);
Greater Or Equal Value (gteq)
$collection->addAttributeToFilter('level', ['gteq' => 1]);
# similar you can do with addFieldToFilter
$collection->addFieldToFilter('level', ['gteq' => 1]);
Less Or Equal Value (lteq)
$collection->addAttributeToFilter('level', ['lteq' => 1]);
# similar you can do with addFieldToFilter
$collection->addFieldToFilter('level', ['lteq' => 1]);
Value In Set (finset)
$collection->addAttributeToFilter('website_ids', ['finset' => $websiteId]);
# similar you can do with addFieldToFilter
$collection->addFieldToFilter('website_ids', ['finset' => $websiteId]);
Value Not In Set (nfinset)
$collection->addAttributeToFilter('website_ids', ['nfinset' => $websiteId]);
# similar you can do with addFieldToFilter
$collection->addFieldToFilter('website_ids', ['nfinset' => $websiteId]);
Regular Expression (regexp)
$collection->addAttributeToFilter('path', ['regexp' => $regexp]);
# similar you can do with addFieldToFilter
$collection->addFieldToFilter('path', ['regexp' => $regexp]);
For more details you can check this class Mysql
I hope this blog is useful to use addAttributeToFilter and addFieldToFilter with different condition types in magento2. In case, I missed anything or need to add some more information, Don’t heisted to leave a comment in this blog, I’ll get back with some positive approach.
Keep loving Keep inspiring Keep liking No sharing