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 = 7148 
WHERE 
  cscart_products_categories.product_id IN (
    99342, 99343, 99404, 99405, 99406, 99407, 
    99408, 99409, 99410, 99411, 99422, 
    99423, 99424, 99425, 99426, 99427, 
    99428, 99429, 99430, 99431, 99432, 
    99433, 99434, 99435, 99436, 99437, 
    99491, 99492, 99493, 99494, 99495, 
    99496, 99497, 99498, 99499, 99500, 
    99501, 99502, 99503, 99504, 99505, 
    99506, 99508, 99509, 99510, 99512, 
    99513, 99514, 99516, 99517, 99518, 
    99519, 99520, 99521, 99522, 99523, 
    99524, 99525, 99526, 99527, 99529, 
    99530, 99531, 99532, 99533, 99534, 
    99535, 99536, 99537, 99538, 99539, 
    99540, 99541, 99542, 99543, 99544, 
    99545, 99546, 99547, 99548, 99549, 
    99550, 99551, 99552, 99553, 99554, 
    99555, 99556, 99557, 99574, 99575, 
    99576, 100143, 100161, 100162, 100163
  ) 
GROUP BY 
  cscart_products_categories.product_id

Query time 0.01675

JSON explain

{
  "query_block": {
    "select_id": 1,
    "cost_info": {
      "query_cost": "136.44"
    },
    "grouping_operation": {
      "using_temporary_table": true,
      "using_filesort": true,
      "cost_info": {
        "sort_cost": "10.89"
      },
      "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": 10,
            "filtered": "1.11",
            "cost_info": {
              "read_cost": "2.33",
              "eval_cost": "1.09",
              "prefix_cost": "121.75",
              "data_read_per_join": "174"
            },
            "used_columns": [
              "product_id",
              "category_id",
              "link_type"
            ],
            "attached_condition": "(`nuie_scalesta_net`.`cscart_products_categories`.`product_id` in (99342,99343,99404,99405,99406,99407,99408,99409,99410,99411,99422,99423,99424,99425,99426,99427,99428,99429,99430,99431,99432,99433,99434,99435,99436,99437,99491,99492,99493,99494,99495,99496,99497,99498,99499,99500,99501,99502,99503,99504,99505,99506,99508,99509,99510,99512,99513,99514,99516,99517,99518,99519,99520,99521,99522,99523,99524,99525,99526,99527,99529,99530,99531,99532,99533,99534,99535,99536,99537,99538,99539,99540,99541,99542,99543,99544,99545,99546,99547,99548,99549,99550,99551,99552,99553,99554,99555,99556,99557,99574,99575,99576,100143,100161,100162,100163))"
          }
        },
        {
          "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": 10,
            "filtered": "100.00",
            "cost_info": {
              "read_cost": "2.72",
              "eval_cost": "1.09",
              "prefix_cost": "125.56",
              "data_read_per_join": "174"
            },
            "used_columns": [
              "product_id",
              "category_id",
              "position"
            ]
          }
        }
      ]
    }
  }
}

Result

product_id category_ids position
99342 7194M
99343 7194M
99404 7263M
99405 7263M
99406 7263M
99407 7263M
99408 7263M
99409 7263M
99410 7263M
99411 7263M
99422 7208M,7241,7309,7346
99423 7208M,7241,7309,7346
99424 7208M,7241,7309,7346
99425 7208M,7241,7309,7346
99426 7208M,7241,7309,7346
99427 7208M,7241,7309,7346
99428 7208M,7241,7309,7346
99429 7208M,7241,7309,7346
99430 7208M,7241,7309,7346
99431 7208M,7241,7309,7346
99432 7208M,7241,7309,7346
99433 7208M,7241,7309,7346
99434 7208M,7241,7309,7346
99435 7208M,7241,7309,7346
99436 7208M,7241,7309,7346
99437 7208M,7241,7309,7346
99491 7194M
99492 7194M
99493 7194M
99494 7194M
99495 7194M
99496 7194M
99497 7194M
99498 7194M
99499 7194M
99500 7194M
99501 7194M
99502 7194M
99503 7194M
99504 7194M
99505 7194M
99506 7194M
99508 7157M,7341,7342,7343
99509 7219M,7313,7338
99510 7219M,7313,7338
99512 7157M,7341,7342,7343
99513 7219M,7313,7338
99514 7219M,7313,7338
99516 7157M,7341,7342,7343
99517 7219M,7313,7338
99518 7219M,7313,7338
99519 7225M,7226
99520 7225M,7226
99521 7225M,7226
99522 7225M,7226
99523 7225M,7226
99524 7225M,7226
99525 7225M,7226
99526 7225M,7226
99527 7225M,7226
99529 7208M,7241,7309,7346
99530 7208M,7241,7309,7346
99531 7208M,7241,7309,7346
99532 7208M,7241,7309,7346
99533 7208M,7241,7309,7346
99534 7208M,7241,7309,7346
99535 7208M,7241,7309,7346
99536 7208M,7241,7309,7346
99537 7208M,7241,7309,7346
99538 7208M,7241,7309,7346
99539 7208M,7241,7309,7346
99540 7208M,7241,7309,7346
99541 7208M,7241,7309,7346
99542 7208M,7241,7309,7346
99543 7208M,7241,7309,7346
99544 7208M,7241,7309,7346
99545 7208M,7241,7309,7346
99546 7208M,7241,7309,7346
99547 7208M,7241,7309,7346
99548 7208M,7241,7309,7346
99549 7208M,7241,7309,7346
99550 7208M,7241,7309,7346
99551 7208M,7241,7309,7346
99552 7208M,7241,7309,7346
99553 7208M,7241,7309,7346
99554 7208M,7241,7309,7346
99555 7208M,7241,7309,7346
99556 7208M,7241,7309,7346
99557 7208M,7241,7309,7346
99574 7208M,7241,7309,7346
99575 7208M,7241,7309,7346
99576 7208M,7241,7309,7346
100143 7247M,7265
100161 7208M,7241,7309,7346
100162 7208M,7241,7309,7346
100163 7208M,7241,7309,7346