• magento2.2.3 根据产品ID获取栏目名称的正确调用方式


    • 根据product_id 获取 category_ids : 
          /**
           * @param $product_id
           * @return array
           */
          public function mc_getCategoryIds($product_id)
          {
      //       +++ get product the category id
              $registry = $this->mc_C['product'];
              $getObj = $this->mc_get_obj($registry);
              /**
               * @var MagentoCatalogModelProduct $getObj
               * MagentoCatalogModelProduct
               */
              $product = $getObj->load($product_id);
      
              /**
               * @var MagentoCatalogModelProduct $product
               * MagentoCatalogModelProduct
               */
      
              return $product->getCategoryIds();
          }
      View Code
    • 获取 category_name :
      /**
           * @param $product_id
           * @return mixed
           */
          public function mc_getCategoryName($product_id)
          {
              $cats = $this->mc_getCategoryIds($product_id);
              if(count($cats) ){
                  $firstCategoryId = $cats[(count($cats)-1)];
                  $registry = $this->mc_C['category'];
                  $getObj = $this->mc_get_obj($registry);
      
                  /**
                   * @var MagentoCatalogModelCategoryFactory $getObj
                   */
                  $_category = $getObj->create();
                  /**
                   * @var MagentoCatalogModelCategoryFactory $_category
                   */
                  $data = $_category->load($firstCategoryId);
                  /**
                   * @var MagentoCatalogModelCategoryFactory $data
                   */
                  return $data->getName();
              }
              return 0;
          }
      View Code

    以上简单的调用了栏目的名称。

    FAQ:

    1,如果使用不正确的 CategoryFactory 类 : 

    • 're_category_c'=>MagentoCatalogModelResourceModelCategoryCollectionFactory::class,//fixme This class MagentoCatalogModelResourceModelCategoryCollection
    • 're_category_f'=>MagentoCatalogModelResourceModelCategoryFactory::class,//fixme This classMagentoCatalogModelResourceModelCategory
    • 're_category'=>MagentoCatalogModelResourceModelCategory::class,//fixme This  Catalog category model

      正确的是:MagentoCatalogModelCategoryFactory

      ResourceModel 与 Model 的区别:

     

     

    Models : Models are where your main business logic should be handled and is a single instance of an object. The model will use the resource model to talk to the database and get/set data for it on save() and load().

    Resource Model : A resource model is where your main C.R.U.D happens (CreateReadUpdateand delete). The resource model shouldn’t contain business logic however it will talk to the adapters and basically talk to the database.

     

    2,如果使用不正确的通用SQL : 

      SQL: 

    select value from catalog_product_entity_varchar left join eav_attribute on
        eav_attribute.attribute_id = catalog_product_entity_varchar.attribute_id
    where
        eav_attribute.attribute_code='name' and 
        catalog_product_entity_varchar.entity_id=2082

      CODE:

    $_connection = $this->mc_get_obj(MagentoFrameworkAppResourceConnection::class);//get class
                $db_connection = $_connection->getConnection(MagentoFrameworkAppResourceConnection::DEFAULT_CONNECTION);//connection
                $category = $db_connection->fetchAll('select * from '.'`catalog_product_entity_varchar` '.'left join '.'`eav_attribute` '.'on '.
                    '`eav_attribute`.'.'`attribute_id`='.'`catalog_product_entity_varchar`.'.'`attribute_id` '.
                    'where '.'`eav_attribute`.'.'`attribute_code`='.'"name" '.'and '. '`catalog_product_entity_varchar`.'.'`entity_id`='.$vi['product_id']);
    
                var_dump($category[0]['value']);die;

      

      正确的SQL: 
      

    SELECT 
      e.entity_id AS product_id
      , e.type_id AS product_type
      , e.sku,
      (
        SELECT
          GROUP_CONCAT(DISTINCT(cv.value))
        FROM 
          catalog_category_entity_varchar AS cv, catalog_category_product AS at_category_id 
        WHERE
          at_category_id.category_id = cv.entity_id
          AND (at_category_id.product_id = e.entity_id) 
          AND cv.attribute_id = 41 and cv.store_id = 0
      ) AS category_name 
    FROM catalog_product_entity AS e where e.entity_id=2082;
  • 相关阅读:
    [EnterpriseLibrary]Microsoft.Practices.ObjectBuilder中的定位器Locator
    [VC++入门]搞了半天我终于知道C++那种头文件h和源文件cpp到底在搞什么
    PS网页设计教程XX——在Photoshop中创建一个七彩糖果店网站布局
    24点的所有组合的解法
    PS网页设计教程XXIII——创建一个售卖iPhone 5应用程序的网站
    PSD转HTML实例教程——利用JQuery插件实现图片滑动效果
    PS网页设计教程XXI——在Photoshop中创建一个光质感网页设计
    24点算法之我见
    PS网页设计教程XIX——在Photoshop中创建一个优雅的作品集的网页布局
    PS网页设计教程XXII——在PS中创建单页复古网页布局
  • 原文地址:https://www.cnblogs.com/q1104460935/p/11237280.html
Copyright © 2020-2023  润新知