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 = 293 
WHERE 
  cscart_products_categories.product_id IN (
    423, 424, 455, 433, 495, 453, 468, 467, 
    418, 420, 421, 422, 406, 407, 437, 494, 
    454, 442, 426, 429, 428, 410, 438, 440, 
    443, 463, 460, 450, 446, 447, 476, 457, 
    482, 483, 472, 441, 405, 403, 485, 492, 
    479, 480, 413, 401, 449, 474, 473, 448
  ) 
GROUP BY 
  cscart_products_categories.product_id

Query time 0.00089

JSON explain

{
  "query_block": {
    "select_id": 1,
    "cost_info": {
      "query_cost": "43.85"
    },
    "grouping_operation": {
      "using_temporary_table": true,
      "using_filesort": true,
      "cost_info": {
        "sort_cost": "1.48"
      },
      "nested_loop": [
        {
          "table": {
            "table_name": "cscart_categories",
            "access_type": "ALL",
            "possible_keys": [
              "PRIMARY",
              "c_status",
              "p_category_id"
            ],
            "rows_examined_per_scan": 98,
            "rows_produced_per_join": 3,
            "filtered": "4.00",
            "cost_info": {
              "read_cost": "22.49",
              "eval_cost": "0.78",
              "prefix_cost": "23.28",
              "data_read_per_join": "13K"
            },
            "used_columns": [
              "category_id",
              "storefront_id",
              "usergroup_ids",
              "status"
            ],
            "attached_condition": "((`danishecarter_latest`.`cscart_categories`.`storefront_id` in (0,1)) and ((`danishecarter_latest`.`cscart_categories`.`usergroup_ids` = '') or find_in_set(0,`danishecarter_latest`.`cscart_categories`.`usergroup_ids`) or find_in_set(1,`danishecarter_latest`.`cscart_categories`.`usergroup_ids`)) and (`danishecarter_latest`.`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": [
              "danishecarter_latest.cscart_categories.category_id"
            ],
            "rows_examined_per_scan": 3,
            "rows_produced_per_join": 1,
            "filtered": "12.57",
            "index_condition": "(`danishecarter_latest`.`cscart_products_categories`.`product_id` in (423,424,455,433,495,453,468,467,418,420,421,422,406,407,437,494,454,442,426,429,428,410,438,440,443,463,460,450,446,447,476,457,482,483,472,441,405,403,485,492,479,480,413,401,449,474,473,448))",
            "cost_info": {
              "read_cost": "14.97",
              "eval_cost": "0.30",
              "prefix_cost": "40.60",
              "data_read_per_join": "23"
            },
            "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",
              "danishecarter_latest.cscart_products_categories.product_id"
            ],
            "rows_examined_per_scan": 1,
            "rows_produced_per_join": 1,
            "filtered": "100.00",
            "cost_info": {
              "read_cost": "1.48",
              "eval_cost": "0.30",
              "prefix_cost": "42.38",
              "data_read_per_join": "23"
            },
            "used_columns": [
              "product_id",
              "category_id",
              "position"
            ]
          }
        }
      ]
    }
  }
}

Result

product_id category_ids position
401 295M
403 302M
405 302M
406 302M
407 302M
410 303M
413 302M
418 302M
420 296M
421 296M
422 296M
423 296M
424 296M
426 303M
428 303M
429 303M
433 296M
437 306M
438 301M
440 301M
441 296M
442 305M
443 295M
446 305M
447 305M
448 303M
449 305M
450 303M
453 304M
454 305M
455 297M
457 305M
460 304M
463 304M
467 302M
468 302M
472 302M
473 303M
474 303M
476 305M
479 302M
480 302M
482 306M
483 305M
485 302M
492 302M
494 296M
495 296M