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 = 7156 
WHERE 
  cscart_products_categories.product_id IN (
    87241, 87244, 87245, 87246, 87249, 87250, 
    87251, 86894, 92232, 92233, 92234, 
    92235, 92236, 92238, 92468, 92472, 
    92473, 92474, 84240, 88588, 84239, 
    92212, 92213, 92214, 92215, 92217, 
    92223, 92465, 92466, 92191, 84238, 
    92228, 92229, 92230, 92231, 92237, 
    92469, 92470, 92471, 91865, 85585, 
    92366, 92367, 92368, 92369, 92370, 
    92371, 92372, 91892, 92150, 84254, 
    84259, 87577, 87592, 87607, 88788, 
    92197, 92457, 85646, 91866, 91867, 
    92325, 92326, 92327, 92328, 90054, 
    90056, 90057, 84252, 84253, 84257, 
    84258, 87575, 87576, 87590, 87591, 
    87605, 87606, 88786, 88787, 85578, 
    87656, 87670, 87677, 87684, 87705, 
    87716, 87717, 87730, 87731, 90022, 
    90024, 90038, 90040, 90041, 92440
  ) 
GROUP BY 
  cscart_products_categories.product_id

Query time 0.01580

JSON explain

{
  "query_block": {
    "select_id": 1,
    "cost_info": {
      "query_cost": "133.82"
    },
    "grouping_operation": {
      "using_temporary_table": true,
      "using_filesort": true,
      "cost_info": {
        "sort_cost": "8.94"
      },
      "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": 8,
            "filtered": "0.91",
            "cost_info": {
              "read_cost": "2.33",
              "eval_cost": "0.89",
              "prefix_cost": "121.75",
              "data_read_per_join": "143"
            },
            "used_columns": [
              "product_id",
              "category_id",
              "link_type"
            ],
            "attached_condition": "(`nuie_scalesta_net`.`cscart_products_categories`.`product_id` in (87241,87244,87245,87246,87249,87250,87251,86894,92232,92233,92234,92235,92236,92238,92468,92472,92473,92474,84240,88588,84239,92212,92213,92214,92215,92217,92223,92465,92466,92191,84238,92228,92229,92230,92231,92237,92469,92470,92471,91865,85585,92366,92367,92368,92369,92370,92371,92372,91892,92150,84254,84259,87577,87592,87607,88788,92197,92457,85646,91866,91867,92325,92326,92327,92328,90054,90056,90057,84252,84253,84257,84258,87575,87576,87590,87591,87605,87606,88786,88787,85578,87656,87670,87677,87684,87705,87716,87717,87730,87731,90022,90024,90038,90040,90041,92440))"
          }
        },
        {
          "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": 8,
            "filtered": "100.00",
            "cost_info": {
              "read_cost": "2.24",
              "eval_cost": "0.89",
              "prefix_cost": "124.88",
              "data_read_per_join": "143"
            },
            "used_columns": [
              "product_id",
              "category_id",
              "position"
            ]
          }
        }
      ]
    }
  }
}

Result

product_id category_ids position
84238 7194M
84239 7194M
84240 7194M
84252 7194M
84253 7194M
84254 7194M
84257 7194M
84258 7194M
84259 7194M
85578 7157M,7341,7342,7343
85585 7157M,7341,7342,7343
85646 7148,7156,7157M 0
86894 7148,7156,7157M 0
87241 7194M
87244 7194M
87245 7194M
87246 7194M
87249 7194M
87250 7194M
87251 7194M
87575 7194M
87576 7194M
87577 7194M
87590 7194M
87591 7194M
87592 7194M
87605 7194M
87606 7194M
87607 7194M
87656 7194M
87670 7194M
87677 7194M
87684 7194M
87705 7194M
87716 7194M
87717 7194M
87730 7194M
87731 7194M
88588 7194M
88786 7194M
88787 7194M
88788 7194M
90022 7194M
90024 7194M
90038 7194M
90040 7194M
90041 7194M
90054 7194M
90056 7194M
90057 7194M
91865 7148M,7156,7157 0
91866 7148M,7156,7157 0
91867 7148M,7156,7157 0
91892 7157M,7341,7342,7343
92150 7157M,7341,7342,7343
92191 7157M,7341,7342,7343
92197 7157M,7341,7342,7343
92212 7157M,7341,7342,7343
92213 7157M,7341,7342,7343
92214 7157M,7341,7342,7343
92215 7157M,7341,7342,7343
92217 7157M,7341,7342,7343
92223 7157M,7341,7342,7343
92228 7157M,7341,7342,7343
92229 7157M,7341,7342,7343
92230 7157M,7341,7342,7343
92231 7157M,7341,7342,7343
92232 7157M,7341,7342,7343
92233 7157M,7341,7342,7343
92234 7157M,7341,7342,7343
92235 7157M,7341,7342,7343
92236 7157M,7341,7342,7343
92237 7157M,7341,7342,7343
92238 7157M,7341,7342,7343
92325 7148M,7156,7157 0
92326 7148M,7156,7157 0
92327 7148M,7156,7157 0
92328 7148M,7156,7157 0
92366 7148M,7156,7157 0
92367 7148M,7156,7157 0
92368 7148M,7156,7157 0
92369 7148M,7156,7157 0
92370 7148M,7156,7157 0
92371 7148M,7156,7157 0
92372 7148M,7156,7157 0
92440 7157M,7341,7342,7343
92457 7157M,7341,7342,7343
92465 7157M,7341,7342,7343
92466 7157M,7341,7342,7343
92468 7157M,7341,7342,7343
92469 7157M,7341,7342,7343
92470 7157M,7341,7342,7343
92471 7157M,7341,7342,7343
92472 7157M,7341,7342,7343
92473 7157M,7341,7342,7343
92474 7157M,7341,7342,7343