SELECT 
  a.*, 
  b.option_name, 
  b.internal_option_name, 
  b.option_text, 
  b.description, 
  b.inner_hint, 
  b.incorrect_message, 
  b.comment 
FROM 
  cscart_product_options as a 
  LEFT JOIN cscart_product_options_descriptions as b ON a.option_id = b.option_id 
  AND b.lang_code = 'vi' 
WHERE 
  a.product_id IN (
    48685, 43657, 47856, 47617, 48866, 47393, 
    47860, 48735, 47179, 48323, 48687, 
    48948, 49320, 44570, 48528, 47857, 
    47863, 47390, 48529, 48686, 48691, 
    40531, 49183, 48689, 15019, 49583, 
    47618, 49221, 49149, 48669, 48324, 
    48690
  ) 
  AND a.status = 'A' 
ORDER BY 
  a.position

Query time 0.00203

JSON explain

{
  "query_block": {
    "select_id": 1,
    "nested_loop": [
      {
        "read_sorted_file": {
          "filesort": {
            "sort_key": "a.position",
            "table": {
              "table_name": "a",
              "access_type": "range",
              "possible_keys": ["c_status"],
              "key": "c_status",
              "key_length": "6",
              "used_key_parts": ["product_id", "status"],
              "rows": 32,
              "filtered": 100,
              "index_condition": "a.product_id in (48685,43657,47856,47617,48866,47393,47860,48735,47179,48323,48687,48948,49320,44570,48528,47857,47863,47390,48529,48686,48691,40531,49183,48689,15019,49583,47618,49221,49149,48669,48324,48690) and a.`status` = 'A'"
            }
          }
        }
      },
      {
        "table": {
          "table_name": "b",
          "access_type": "eq_ref",
          "possible_keys": ["PRIMARY"],
          "key": "PRIMARY",
          "key_length": "9",
          "used_key_parts": ["option_id", "lang_code"],
          "ref": ["dev_db.a.option_id", "const"],
          "rows": 1,
          "filtered": 100,
          "attached_condition": "trigcond(b.lang_code = 'vi')"
        }
      }
    ]
  }
}