SELECT 
  vi_products_categories.product_id, 
  GROUP_CONCAT(
    IF(
      vi_products_categories.link_type = "M", 
      CONCAT(
        vi_products_categories.category_id, 
        "M"
      ), 
      vi_products_categories.category_id
    )
  ) AS category_ids, 
  product_position_source.position AS position 
FROM 
  vi_products_categories 
  INNER JOIN vi_categories ON vi_categories.category_id = vi_products_categories.category_id 
  AND vi_categories.storefront_id IN (0, 1) 
  AND (
    vi_categories.usergroup_ids = '' 
    OR FIND_IN_SET(0, vi_categories.usergroup_ids) 
    OR FIND_IN_SET(1, vi_categories.usergroup_ids)
  ) 
  AND vi_categories.status IN ('A', 'H') 
  LEFT JOIN vi_products_categories AS product_position_source ON vi_products_categories.product_id = product_position_source.product_id 
  AND product_position_source.category_id = 223 
WHERE 
  vi_products_categories.product_id IN (
    12, 78, 79, 11, 41, 81, 107, 109, 91, 92, 
    34, 15, 31, 38, 80, 102, 28, 280, 282, 
    278
  ) 
GROUP BY 
  vi_products_categories.product_id

Query time 0.00031

JSON explain

{
  "query_block": {
    "select_id": 1,
    "nested_loop": [
      {
        "table": {
          "table_name": "vi_products_categories",
          "access_type": "range",
          "possible_keys": ["PRIMARY", "pt"],
          "key": "pt",
          "key_length": "3",
          "used_key_parts": ["product_id"],
          "rows": 26,
          "filtered": 100,
          "index_condition": "vi_products_categories.product_id in (12,78,79,11,41,81,107,109,91,92,34,15,31,38,80,102,28,280,282,278)"
        }
      },
      {
        "table": {
          "table_name": "vi_categories",
          "access_type": "eq_ref",
          "possible_keys": ["PRIMARY", "c_status", "p_category_id"],
          "key": "PRIMARY",
          "key_length": "3",
          "used_key_parts": ["category_id"],
          "ref": ["devvipiriscom.vi_products_categories.category_id"],
          "rows": 1,
          "filtered": 100,
          "attached_condition": "vi_categories.storefront_id in (0,1) and (vi_categories.usergroup_ids = '' or find_in_set(0,vi_categories.usergroup_ids) or find_in_set(1,vi_categories.usergroup_ids)) and vi_categories.`status` in ('A','H')"
        }
      },
      {
        "table": {
          "table_name": "product_position_source",
          "access_type": "eq_ref",
          "possible_keys": ["PRIMARY", "pt"],
          "key": "PRIMARY",
          "key_length": "6",
          "used_key_parts": ["category_id", "product_id"],
          "ref": ["const", "devvipiriscom.vi_products_categories.product_id"],
          "rows": 1,
          "filtered": 100
        }
      }
    ]
  }
}

Result

product_id category_ids position
11 224M
12 224M
15 224M
28 225M
31 225M
34 225M
38 225M
41 225M
78 226M
79 226M
80 226M
81 226M
91 227M
92 227M
102 227M
107 227M
109 227M
278 224M
280 224M
282 224M