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 = 7166 
WHERE 
  cscart_products_categories.product_id IN (
    100983, 100984, 100985, 100986, 100987, 
    100988, 100989, 100990, 100991, 100992, 
    100993, 100994, 100995, 100996, 100997, 
    100998, 100999, 101000, 101001, 101002, 
    101003, 101004, 101005, 101006, 101007, 
    101008, 101009, 101010, 101093, 101094, 
    101095, 101096, 101097, 101098, 101099, 
    101100, 101101, 101102, 101103, 101104, 
    101628, 101629, 101630, 101631, 101632, 
    101633, 101678, 101679
  ) 
GROUP BY 
  cscart_products_categories.product_id

Query time 0.01528

JSON explain

{
  "query_block": {
    "select_id": 1,
    "cost_info": {
      "query_cost": "99.30"
    },
    "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": 110,
            "rows_produced_per_join": 110,
            "filtered": "100.00",
            "using_index": true,
            "cost_info": {
              "read_cost": "11.30",
              "eval_cost": "11.00",
              "prefix_cost": "22.30",
              "data_read_per_join": "1K"
            },
            "used_columns": [
              "product_id",
              "category_id",
              "link_type"
            ],
            "attached_condition": "(`nuie_scalesta_net`.`cscart_products_categories`.`product_id` in (100983,100984,100985,100986,100987,100988,100989,100990,100991,100992,100993,100994,100995,100996,100997,100998,100999,101000,101001,101002,101003,101004,101005,101006,101007,101008,101009,101010,101093,101094,101095,101096,101097,101098,101099,101100,101101,101102,101103,101104,101628,101629,101630,101631,101632,101633,101678,101679))"
          }
        },
        {
          "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": 110,
            "filtered": "100.00",
            "cost_info": {
              "read_cost": "27.50",
              "eval_cost": "11.00",
              "prefix_cost": "60.80",
              "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": 5,
            "filtered": "5.00",
            "cost_info": {
              "read_cost": "27.50",
              "eval_cost": "0.55",
              "prefix_cost": "99.30",
              "data_read_per_join": "14K"
            },
            "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
100983 7167M,7183,7283
100984 7167M,7183,7283
100985 7193M,7319
100986 7193M,7319
100987 7193M,7319
100988 7167M,7183,7283
100989 7193M,7319
100990 7193M,7319
100991 7193M,7319
100992 7193M,7319
100993 7193M,7319
100994 7193M,7319
100995 7193M,7319
100996 7193M,7319
100997 7193M,7319
100998 7193M,7319
100999 7193M,7319
101000 7193M,7319
101001 7193M,7319
101002 7193M,7319
101003 7193M,7319
101004 7193M,7319
101005 7193M,7319
101006 7193M,7319
101007 7193M,7319
101008 7193M,7319
101009 7193M,7319
101010 7193M,7319
101093 7193M,7319
101094 7193M,7319
101095 7193M,7319
101096 7193M,7319
101097 7193M,7319
101098 7193M,7319
101099 7193M,7319
101100 7193M,7319
101101 7193M,7319
101102 7167M,7183,7283
101103 7167M,7183,7283
101104 7167M,7183,7283
101628 7167M,7183,7283
101629 7167M,7183,7283
101630 7167M,7183,7283
101631 7167M,7183,7283
101632 7167M,7183,7283
101633 7167M,7183,7283
101678 7167M,7183,7283
101679 7167M,7183,7283