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 = 7182 
WHERE 
  cscart_products_categories.product_id IN (
    86856, 85583, 82561, 90268, 90264, 90266, 
    90273, 91311, 91313, 91315, 90267, 
    90274, 85649, 85650, 85651, 91312, 
    91314, 91316, 90263, 90270, 90269, 
    90275, 90265, 93356, 93357, 93358, 
    94117, 94958, 95683, 95702, 95703, 
    96841, 96918, 96919, 96998, 98482, 
    98538, 98539, 98540, 98541, 98542, 
    98543, 98544, 98545, 98546, 98547, 
    98548, 98549
  ) 
GROUP BY 
  cscart_products_categories.product_id

Query time 0.01982

JSON explain

{
  "query_block": {
    "select_id": 1,
    "cost_info": {
      "query_cost": "129.31"
    },
    "grouping_operation": {
      "using_temporary_table": true,
      "using_filesort": true,
      "cost_info": {
        "sort_cost": "5.60"
      },
      "nested_loop": [
        {
          "table": {
            "table_name": "cscart_categories",
            "access_type": "ALL",
            "possible_keys": [
              "PRIMARY",
              "c_status",
              "p_category_id"
            ],
            "rows_examined_per_scan": 208,
            "rows_produced_per_join": 8,
            "filtered": "4.00",
            "cost_info": {
              "read_cost": "20.72",
              "eval_cost": "0.83",
              "prefix_cost": "21.55",
              "data_read_per_join": "21K"
            },
            "used_columns": [
              "category_id",
              "usergroup_ids",
              "status",
              "storefront_id"
            ],
            "attached_condition": "((`nuie_scalesta_net`.`cscart_categories`.`storefront_id` in (0,1)) and ((`nuie_scalesta_net`.`cscart_categories`.`usergroup_ids` = '') or (0 <> find_in_set(0,`nuie_scalesta_net`.`cscart_categories`.`usergroup_ids`)) or (0 <> find_in_set(1,`nuie_scalesta_net`.`cscart_categories`.`usergroup_ids`))) and (`nuie_scalesta_net`.`cscart_categories`.`status` in ('A','H')))"
          }
        },
        {
          "table": {
            "table_name": "cscart_products_categories",
            "access_type": "ref",
            "possible_keys": [
              "PRIMARY",
              "link_type",
              "pt"
            ],
            "key": "PRIMARY",
            "used_key_parts": [
              "category_id"
            ],
            "key_length": "3",
            "ref": [
              "nuie_scalesta_net.cscart_categories.category_id"
            ],
            "rows_examined_per_scan": 117,
            "rows_produced_per_join": 5,
            "filtered": "0.57",
            "cost_info": {
              "read_cost": "2.33",
              "eval_cost": "0.56",
              "prefix_cost": "121.75",
              "data_read_per_join": "89"
            },
            "used_columns": [
              "product_id",
              "category_id",
              "link_type"
            ],
            "attached_condition": "(`nuie_scalesta_net`.`cscart_products_categories`.`product_id` in (86856,85583,82561,90268,90264,90266,90273,91311,91313,91315,90267,90274,85649,85650,85651,91312,91314,91316,90263,90270,90269,90275,90265,93356,93357,93358,94117,94958,95683,95702,95703,96841,96918,96919,96998,98482,98538,98539,98540,98541,98542,98543,98544,98545,98546,98547,98548,98549))"
          }
        },
        {
          "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",
              "nuie_scalesta_net.cscart_products_categories.product_id"
            ],
            "rows_examined_per_scan": 1,
            "rows_produced_per_join": 5,
            "filtered": "100.00",
            "cost_info": {
              "read_cost": "1.40",
              "eval_cost": "0.56",
              "prefix_cost": "123.71",
              "data_read_per_join": "89"
            },
            "used_columns": [
              "product_id",
              "category_id",
              "position"
            ]
          }
        }
      ]
    }
  }
}

Result

product_id category_ids position
82561 7167M,7183,7283
85583 7149M,7182,7300 0
85649 7167M,7183,7283
85650 7167M,7183,7283
85651 7167M,7183,7283
86856 7149M,7182,7300 0
90263 7167M,7183,7283
90264 7167M,7183,7283
90265 7167M,7183,7283
90266 7167M,7183,7283
90267 7167M,7183,7283
90268 7167M,7183,7283
90269 7167M,7183,7283
90270 7167M,7183,7283
90273 7167M,7183,7283
90274 7167M,7183,7283
90275 7167M,7183,7283
91311 7167M,7183,7283
91312 7167M,7183,7283
91313 7167M,7183,7283
91314 7167M,7183,7283
91315 7167M,7183,7283
91316 7167M,7183,7283
93356 7167M,7183,7283
93357 7167M,7183,7283
93358 7167M,7183,7283
94117 7167M,7183,7283
94958 7167M,7183,7283
95683 7167M,7183,7283
95702 7167M,7183,7283
95703 7167M,7183,7283
96841 7167M,7183,7283
96918 7167M,7183,7283
96919 7167M,7183,7283
96998 7167M,7183,7283
98482 7149M,7182,7300 0
98538 7167M,7183,7283
98539 7167M,7183,7283
98540 7167M,7183,7283
98541 7167M,7183,7283
98542 7167M,7183,7283
98543 7167M,7183,7283
98544 7167M,7183,7283
98545 7167M,7183,7283
98546 7167M,7183,7283
98547 7167M,7183,7283
98548 7167M,7183,7283
98549 7167M,7183,7283