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 = 7165 
WHERE 
  cscart_products_categories.product_id IN (
    101544, 101545, 101546, 101628, 101629, 
    101630, 101631, 101632, 101633, 101634, 
    101678, 101679, 101680, 101681, 101740, 
    101741, 101742, 101743, 101854, 101855, 
    101856, 101857, 101858, 101859, 101860, 
    101861, 101862, 101863, 101864, 101865, 
    101866, 101867, 101868, 101869, 101870, 
    101871, 101928, 101929, 101930, 101931, 
    101956, 101957, 101958, 101959, 101960, 
    101961, 101962
  ) 
GROUP BY 
  cscart_products_categories.product_id

Query time 0.01519

JSON explain

{
  "query_block": {
    "select_id": 1,
    "cost_info": {
      "query_cost": "111.90"
    },
    "grouping_operation": {
      "using_filesort": false,
      "nested_loop": [
        {
          "table": {
            "table_name": "cscart_products_categories",
            "access_type": "range",
            "possible_keys": [
              "PRIMARY",
              "link_type",
              "pt"
            ],
            "key": "pt",
            "used_key_parts": [
              "product_id"
            ],
            "key_length": "3",
            "rows_examined_per_scan": 124,
            "rows_produced_per_join": 124,
            "filtered": "100.00",
            "using_index": true,
            "cost_info": {
              "read_cost": "12.71",
              "eval_cost": "12.40",
              "prefix_cost": "25.11",
              "data_read_per_join": "1K"
            },
            "used_columns": [
              "product_id",
              "category_id",
              "link_type"
            ],
            "attached_condition": "(`nuie_scalesta_net`.`cscart_products_categories`.`product_id` in (101544,101545,101546,101628,101629,101630,101631,101632,101633,101634,101678,101679,101680,101681,101740,101741,101742,101743,101854,101855,101856,101857,101858,101859,101860,101861,101862,101863,101864,101865,101866,101867,101868,101869,101870,101871,101928,101929,101930,101931,101956,101957,101958,101959,101960,101961,101962))"
          }
        },
        {
          "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": 124,
            "filtered": "100.00",
            "cost_info": {
              "read_cost": "31.00",
              "eval_cost": "12.40",
              "prefix_cost": "68.51",
              "data_read_per_join": "1K"
            },
            "used_columns": [
              "product_id",
              "category_id",
              "position"
            ]
          }
        },
        {
          "table": {
            "table_name": "cscart_categories",
            "access_type": "eq_ref",
            "possible_keys": [
              "PRIMARY",
              "c_status",
              "p_category_id"
            ],
            "key": "PRIMARY",
            "used_key_parts": [
              "category_id"
            ],
            "key_length": "3",
            "ref": [
              "nuie_scalesta_net.cscart_products_categories.category_id"
            ],
            "rows_examined_per_scan": 1,
            "rows_produced_per_join": 6,
            "filtered": "5.00",
            "cost_info": {
              "read_cost": "31.00",
              "eval_cost": "0.62",
              "prefix_cost": "111.91",
              "data_read_per_join": "16K"
            },
            "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')))"
          }
        }
      ]
    }
  }
}

Result

product_id category_ids position
101544 7179M
101545 7176M
101546 7176M
101628 7167M,7183,7283
101629 7167M,7183,7283
101630 7167M,7183,7283
101631 7167M,7183,7283
101632 7167M,7183,7283
101633 7167M,7183,7283
101634 7176M
101678 7167M,7183,7283
101679 7167M,7183,7283
101680 7167M,7183,7283
101681 7167M,7183,7283
101740 7167M,7183,7283
101741 7167M,7183,7283
101742 7167M,7183,7283
101743 7167M,7183,7283
101854 7167M,7183,7283
101855 7167M,7183,7283
101856 7167M,7183,7283
101857 7167M,7183,7283
101858 7167M,7183,7283
101859 7167M,7183,7283
101860 7167M,7183,7283
101861 7167M,7183,7283
101862 7167M,7183,7283
101863 7167M,7183,7283
101864 7167M,7183,7283
101865 7167M,7183,7283
101866 7167M,7183,7283
101867 7167M,7183,7283
101868 7167M,7183,7283
101869 7167M,7183,7283
101870 7167M,7183,7283
101871 7167M,7183,7283
101928 7167M,7183,7283
101929 7167M,7183,7283
101930 7167M,7183,7283
101931 7167M,7183,7283
101956 7176M
101957 7176M
101958 7193M,7319
101959 7193M,7319
101960 7193M,7319
101961 7193M,7319
101962 7193M,7319