SELECT 
  cscart_products_categories.product_id, 
  GROUP_CONCAT(
    IF(
      cscart_products_categories.link_type = "M", 
      CONCAT(
        cscart_products_categories.category_id, 
        "M"
      ), 
      cscart_products_categories.category_id
    )
  ) AS category_ids, 
  product_position_source.position AS position 
FROM 
  cscart_products_categories 
  INNER JOIN cscart_categories ON cscart_categories.category_id = cscart_products_categories.category_id 
  AND cscart_categories.storefront_id IN (0, 1) 
  AND (
    cscart_categories.usergroup_ids = '' 
    OR FIND_IN_SET(
      0, cscart_categories.usergroup_ids
    ) 
    OR FIND_IN_SET(
      1, cscart_categories.usergroup_ids
    )
  ) 
  AND cscart_categories.status IN ('A', 'H') 
  LEFT JOIN cscart_products_categories AS product_position_source ON cscart_products_categories.product_id = product_position_source.product_id 
  AND product_position_source.category_id = 3 
WHERE 
  cscart_products_categories.product_id IN (
    822, 662, 806, 805, 804, 803, 802, 801, 
    800, 799, 796, 792, 786, 782, 744, 743, 
    742, 741, 727, 720, 718, 716, 713, 701, 
    671, 670, 664, 663, 658, 657, 656, 651, 
    377, 371, 369, 368, 362, 228, 219, 218, 
    217, 211, 207, 204, 202, 195, 192, 189
  ) 
GROUP BY 
  cscart_products_categories.product_id

Query time 0.00123

JSON explain

{
  "query_block": {
    "select_id": 1,
    "cost_info": {
      "query_cost": "16.06"
    },
    "grouping_operation": {
      "using_temporary_table": true,
      "using_filesort": true,
      "cost_info": {
        "sort_cost": "4.59"
      },
      "nested_loop": [
        {
          "table": {
            "table_name": "cscart_categories",
            "access_type": "ALL",
            "possible_keys": [
              "PRIMARY",
              "c_status",
              "p_category_id"
            ],
            "rows_examined_per_scan": 20,
            "rows_produced_per_join": 1,
            "filtered": "5.00",
            "cost_info": {
              "read_cost": "2.52",
              "eval_cost": "0.10",
              "prefix_cost": "2.62",
              "data_read_per_join": "2K"
            },
            "used_columns": [
              "category_id",
              "usergroup_ids",
              "status",
              "storefront_id"
            ],
            "attached_condition": "((`betaatif_store`.`cscart_categories`.`storefront_id` in (0,1)) and ((`betaatif_store`.`cscart_categories`.`usergroup_ids` = '') or (0 <> find_in_set(0,`betaatif_store`.`cscart_categories`.`usergroup_ids`)) or (0 <> find_in_set(1,`betaatif_store`.`cscart_categories`.`usergroup_ids`))) and (`betaatif_store`.`cscart_categories`.`status` in ('A','H')))"
          }
        },
        {
          "table": {
            "table_name": "cscart_products_categories",
            "access_type": "ref",
            "possible_keys": [
              "PRIMARY",
              "pt"
            ],
            "key": "PRIMARY",
            "used_key_parts": [
              "category_id"
            ],
            "key_length": "3",
            "ref": [
              "betaatif_store.cscart_categories.category_id"
            ],
            "rows_examined_per_scan": 43,
            "rows_produced_per_join": 4,
            "filtered": "10.68",
            "index_condition": "(`betaatif_store`.`cscart_products_categories`.`product_id` in (822,662,806,805,804,803,802,801,800,799,796,792,786,782,744,743,742,741,727,720,718,716,713,701,671,670,664,663,658,657,656,651,377,371,369,368,362,228,219,218,217,211,207,204,202,195,192,189))",
            "cost_info": {
              "read_cost": "2.94",
              "eval_cost": "0.46",
              "prefix_cost": "9.86",
              "data_read_per_join": "73"
            },
            "used_columns": [
              "product_id",
              "category_id",
              "link_type"
            ]
          }
        },
        {
          "table": {
            "table_name": "product_position_source",
            "access_type": "eq_ref",
            "possible_keys": [
              "PRIMARY",
              "pt"
            ],
            "key": "PRIMARY",
            "used_key_parts": [
              "category_id",
              "product_id"
            ],
            "key_length": "6",
            "ref": [
              "const",
              "betaatif_store.cscart_products_categories.product_id"
            ],
            "rows_examined_per_scan": 1,
            "rows_produced_per_join": 4,
            "filtered": "100.00",
            "cost_info": {
              "read_cost": "1.15",
              "eval_cost": "0.46",
              "prefix_cost": "11.47",
              "data_read_per_join": "73"
            },
            "used_columns": [
              "product_id",
              "category_id",
              "position"
            ]
          }
        }
      ]
    }
  }
}

Result

product_id category_ids position
189 15M
192 15M
195 15M
202 16M
204 16M
207 16M
211 16M
217 16M
218 16M
219 16M
228 15M
362 15M
368 15M
369 15M
371 15M
377 15M
651 16M
656 15M,3 0
657 3,15M 0
658 3,15M 0
662 3,15M 0
663 3,15M 0
664 15M,3 0
670 15M
671 15M
701 15M
713 15M
716 15M
718 15M
720 15M
727 15M
741 15M
742 15M
743 15M
744 15M
782 15M
786 15M
792 15M
796 15M
799 15M
800 15M
801 15M
802 15M
803 15M
804 15M
805 15M
806 15M
822 15M