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 = 7156 
WHERE 
  cscart_products_categories.product_id IN (
    98187, 98188, 98189, 98190, 98191, 98200, 
    98201, 98202, 98203, 98204, 98205, 
    98206, 98207, 98391, 98392, 98393, 
    98394, 98395, 98396, 98397, 98398, 
    98399, 98400, 98401, 98402, 98403, 
    98404, 98405, 98406, 98411, 98412, 
    98413, 98422, 98427, 98429, 98433, 
    98435, 98439, 98440, 98441, 98443, 
    98447, 98451, 98453, 98456, 98476, 
    98477, 98478, 98479, 98480, 98481, 
    98483, 98484, 98490, 98492, 98759, 
    98769, 98770, 98771, 98772, 98831, 
    98832, 98833, 98834, 98835, 98836, 
    98837, 98838, 98839, 98840, 98841, 
    98842, 98843, 98844, 98845, 98846, 
    98847, 98848, 98849, 98850, 98897, 
    98914, 98915, 98916, 98917, 98918, 
    98919, 98920, 98921, 98922, 98923, 
    98924, 98925, 98926, 98927, 98928
  ) 
GROUP BY 
  cscart_products_categories.product_id

Query time 0.01685

JSON explain

{
  "query_block": {
    "select_id": 1,
    "cost_info": {
      "query_cost": "136.39"
    },
    "grouping_operation": {
      "using_temporary_table": true,
      "using_filesort": true,
      "cost_info": {
        "sort_cost": "10.85"
      },
      "nested_loop": [
        {
          "table": {
            "table_name": "cscart_categories",
            "access_type": "ALL",
            "possible_keys": [
              "PRIMARY",
              "c_status",
              "p_category_id"
            ],
            "rows_examined_per_scan": 208,
            "rows_produced_per_join": 8,
            "filtered": "4.00",
            "cost_info": {
              "read_cost": "20.72",
              "eval_cost": "0.83",
              "prefix_cost": "21.55",
              "data_read_per_join": "21K"
            },
            "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')))"
          }
        },
        {
          "table": {
            "table_name": "cscart_products_categories",
            "access_type": "ref",
            "possible_keys": [
              "PRIMARY",
              "link_type",
              "pt"
            ],
            "key": "PRIMARY",
            "used_key_parts": [
              "category_id"
            ],
            "key_length": "3",
            "ref": [
              "nuie_scalesta_net.cscart_categories.category_id"
            ],
            "rows_examined_per_scan": 117,
            "rows_produced_per_join": 10,
            "filtered": "1.11",
            "cost_info": {
              "read_cost": "2.33",
              "eval_cost": "1.08",
              "prefix_cost": "121.75",
              "data_read_per_join": "173"
            },
            "used_columns": [
              "product_id",
              "category_id",
              "link_type"
            ],
            "attached_condition": "(`nuie_scalesta_net`.`cscart_products_categories`.`product_id` in (98187,98188,98189,98190,98191,98200,98201,98202,98203,98204,98205,98206,98207,98391,98392,98393,98394,98395,98396,98397,98398,98399,98400,98401,98402,98403,98404,98405,98406,98411,98412,98413,98422,98427,98429,98433,98435,98439,98440,98441,98443,98447,98451,98453,98456,98476,98477,98478,98479,98480,98481,98483,98484,98490,98492,98759,98769,98770,98771,98772,98831,98832,98833,98834,98835,98836,98837,98838,98839,98840,98841,98842,98843,98844,98845,98846,98847,98848,98849,98850,98897,98914,98915,98916,98917,98918,98919,98920,98921,98922,98923,98924,98925,98926,98927,98928))"
          }
        },
        {
          "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": 10,
            "filtered": "100.00",
            "cost_info": {
              "read_cost": "2.71",
              "eval_cost": "1.08",
              "prefix_cost": "125.54",
              "data_read_per_join": "173"
            },
            "used_columns": [
              "product_id",
              "category_id",
              "position"
            ]
          }
        }
      ]
    }
  }
}

Result

product_id category_ids position
98187 7157M,7341,7342,7343
98188 7157M,7341,7342,7343
98189 7157M,7341,7342,7343
98190 7157M,7341,7342,7343
98191 7157M,7341,7342,7343
98200 7157M,7341,7342,7343
98201 7157M,7341,7342,7343
98202 7157M,7341,7342,7343
98203 7157M,7341,7342,7343
98204 7157M,7341,7342,7343
98205 7157M,7341,7342,7343
98206 7157M,7341,7342,7343
98207 7157M,7341,7342,7343
98391 7157M,7341,7342,7343
98392 7157M,7341,7342,7343
98393 7157M,7341,7342,7343
98394 7157M,7341,7342,7343
98395 7157M,7341,7342,7343
98396 7157M,7341,7342,7343
98397 7157M,7341,7342,7343
98398 7157M,7341,7342,7343
98399 7157M,7341,7342,7343
98400 7157M,7341,7342,7343
98401 7157M,7341,7342,7343
98402 7157M,7341,7342,7343
98403 7157M,7341,7342,7343
98404 7157M,7341,7342,7343
98405 7157M,7341,7342,7343
98406 7157M,7341,7342,7343
98411 7157M,7341,7342,7343
98412 7157M,7341,7342,7343
98413 7157M,7341,7342,7343
98422 7157M,7341,7342,7343
98427 7157M,7341,7342,7343
98429 7157M,7341,7342,7343
98433 7157M,7341,7342,7343
98435 7157M,7341,7342,7343
98439 7157M,7341,7342,7343
98440 7157M,7341,7342,7343
98441 7157M,7341,7342,7343
98443 7157M,7341,7342,7343
98447 7157M,7341,7342,7343
98451 7157M,7341,7342,7343
98453 7157M,7341,7342,7343
98456 7157M,7341,7342,7343
98476 7157M,7341,7342,7343
98477 7157M,7341,7342,7343
98478 7157M,7341,7342,7343
98479 7157M,7341,7342,7343
98480 7157M,7341,7342,7343
98481 7157M,7341,7342,7343
98483 7157M,7341,7342,7343
98484 7157M,7341,7342,7343
98490 7157M,7341,7342,7343
98492 7157M,7341,7342,7343
98759 7157M,7341,7342,7343
98769 7157M,7341,7342,7343
98770 7157M,7341,7342,7343
98771 7157M,7341,7342,7343
98772 7157M,7341,7342,7343
98831 7194M
98832 7194M
98833 7194M
98834 7194M
98835 7194M
98836 7194M
98837 7194M
98838 7194M
98839 7194M
98840 7194M
98841 7194M
98842 7194M
98843 7194M
98844 7194M
98845 7194M
98846 7194M
98847 7194M
98848 7194M
98849 7194M
98850 7194M
98897 7157M,7341,7342,7343
98914 7194M
98915 7194M
98916 7194M
98917 7194M
98918 7194M
98919 7194M
98920 7194M
98921 7194M
98922 7194M
98923 7194M
98924 7194M
98925 7194M
98926 7194M
98927 7194M
98928 7194M