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 = 2 
WHERE 
  cscart_products_categories.product_id IN (
    724, 723, 809, 810, 720, 718, 717, 716, 
    715, 713, 709, 708, 707, 705, 701, 697, 
    696, 695, 693, 682, 676, 673, 671, 670, 
    664, 663, 658, 657, 656, 651, 650, 647, 
    645, 644, 641, 639, 636, 624, 622, 620, 
    619, 618, 616, 615, 608, 607, 600, 377
  ) 
GROUP BY 
  cscart_products_categories.product_id

Query time 0.00136

JSON explain

{
  "query_block": {
    "select_id": 1,
    "cost_info": {
      "query_cost": "15.95"
    },
    "grouping_operation": {
      "using_temporary_table": true,
      "using_filesort": true,
      "cost_info": {
        "sort_cost": "4.51"
      },
      "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.50",
            "index_condition": "(`betaatif_store`.`cscart_products_categories`.`product_id` in (724,723,809,810,720,718,717,716,715,713,709,708,707,705,701,697,696,695,693,682,676,673,671,670,664,663,658,657,656,651,650,647,645,644,641,639,636,624,622,620,619,618,616,615,608,607,600,377))",
            "cost_info": {
              "read_cost": "2.94",
              "eval_cost": "0.45",
              "prefix_cost": "9.86",
              "data_read_per_join": "72"
            },
            "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.13",
              "eval_cost": "0.45",
              "prefix_cost": "11.44",
              "data_read_per_join": "72"
            },
            "used_columns": [
              "product_id",
              "category_id",
              "position"
            ]
          }
        }
      ]
    }
  }
}

Result

product_id category_ids position
377 15M
600 5M
607 5M
608 5M
615 5M
616 17M
618 18M
619 5M
620 5M
622 5M
624 17M
636 2M,17 0
639 2M,17 0
641 17,2M 0
644 2M,17 0
645 18M
647 2,17M 0
650 2M,17 0
651 16M
656 3,15M
657 15M,3
658 15M,3
663 15M,3
664 3,15M
670 15M
671 15M
673 17,2M 0
676 5M
682 5M
693 5M
695 5M
696 5M
697 5M
701 15M
705 5M
707 17M
708 5M
709 5M
713 15M
715 5M
716 15M
717 17M
718 15M
720 15M
723 17M
724 18M
809 5M
810 5M