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 = 280 
WHERE 
  cscart_products_categories.product_id IN (
    6946, 6945, 3411, 3415, 3417, 6942, 3410, 
    3413, 3416, 6940, 3414, 6938, 6941, 
    6944, 3412, 6937, 6939, 6943, 3165, 
    3139, 3140, 6712, 6713, 3135, 5802, 
    6970, 6971, 6972, 6973, 6974, 6975, 
    3403, 3404, 3405, 3406, 3408, 3409, 
    6930, 6931, 6932, 6933, 6934, 6935, 
    6936, 3407, 2666, 3845, 2667
  ) 
GROUP BY 
  cscart_products_categories.product_id

Query time 0.00262

JSON explain

{
  "query_block": {
    "select_id": 1,
    "cost_info": {
      "query_cost": "68.35"
    },
    "grouping_operation": {
      "using_temporary_table": true,
      "using_filesort": true,
      "cost_info": {
        "sort_cost": "1.52"
      },
      "nested_loop": [
        {
          "table": {
            "table_name": "cscart_categories",
            "access_type": "ALL",
            "possible_keys": [
              "PRIMARY",
              "c_status",
              "p_category_id"
            ],
            "rows_examined_per_scan": 40,
            "rows_produced_per_join": 1,
            "filtered": "4.00",
            "cost_info": {
              "read_cost": "4.54",
              "eval_cost": "0.16",
              "prefix_cost": "4.70",
              "data_read_per_join": "6K"
            },
            "used_columns": [
              "category_id",
              "storefront_id",
              "usergroup_ids",
              "status"
            ],
            "attached_condition": "((`gaseus`.`cscart_categories`.`storefront_id` in (0,1)) and ((`gaseus`.`cscart_categories`.`usergroup_ids` = '') or (0 <> find_in_set(0,`gaseus`.`cscart_categories`.`usergroup_ids`)) or (0 <> find_in_set(1,`gaseus`.`cscart_categories`.`usergroup_ids`))) and (`gaseus`.`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": [
              "gaseus.cscart_categories.category_id"
            ],
            "rows_examined_per_scan": 110,
            "rows_produced_per_join": 1,
            "filtered": "0.86",
            "index_condition": "(`gaseus`.`cscart_products_categories`.`product_id` in (6946,6945,3411,3415,3417,6942,3410,3413,3416,6940,3414,6938,6941,6944,3412,6937,6939,6943,3165,3139,3140,6712,6713,3135,5802,6970,6971,6972,6973,6974,6975,3403,3404,3405,3406,3408,3409,6930,6931,6932,6933,6934,6935,6936,3407,2666,3845,2667))",
            "cost_info": {
              "read_cost": "44.00",
              "eval_cost": "0.15",
              "prefix_cost": "66.30",
              "data_read_per_join": "24"
            },
            "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",
              "gaseus.cscart_products_categories.product_id"
            ],
            "rows_examined_per_scan": 1,
            "rows_produced_per_join": 1,
            "filtered": "100.00",
            "cost_info": {
              "read_cost": "0.38",
              "eval_cost": "0.15",
              "prefix_cost": "66.83",
              "data_read_per_join": "24"
            },
            "used_columns": [
              "product_id",
              "category_id",
              "position"
            ]
          }
        }
      ]
    }
  }
}

Result

product_id category_ids position
2666 309M
2667 309M
3135 292M
3139 289M
3140 289M
3165 289M
3403 292M
3404 292M
3405 292M
3406 292M
3407 292M
3408 292M
3409 292M
3410 288M
3411 288M
3412 267,288M,282
3413 288M
3414 267,282,288M
3415 288M
3416 288M
3417 288M
3845 309M
5802 287,286M,272
6712 289M
6713 289M
6930 292M
6931 292M
6932 292M
6933 292M
6934 292M
6935 292M
6936 292M
6937 267,288M,282
6938 267,288M,282
6939 267,288M,282
6940 288M
6941 288M,267,282
6942 288M
6943 267,282,288M
6944 288M,267,282
6945 288M,267,282
6946 267,288M,282
6970 312,284M,267,282
6971 267,282,284M,312
6972 282,267,284M,312
6973 312,282,284M,267
6974 284M,312,267,282
6975 284M,312,267,282