PDO to opakowanie bazy danych, które może zrobić dla Ciebie wiele rzeczy. Na przykład
- powiąż wartości wejściowe bezpośrednio w execute()
- otrzymaj zwrócone dane już w żądanym formacie
W rzeczywistości potrzebujesz dwa razy mniej kodu niż masz teraz:
$currency_codes = array("USD", "RUB");
$currency_codes_in = implode(',', array_fill(0, count($currency_codes), '?'));
$query = "SELECT `curr_id` FROM `dictionary_currency` WHERE `curr_code` IN ($currency_codes_in)";
$stmt = $db->prepare($query);
$stmt->execute($currency_codes);
$arr = $stmt->fetchAll(PDO::FETCH_COLUMN);
czy raczej proponuję zrobić to tak
$query = "SELECT curr_code, curr_id FROM dictionary_currency WHERE `curr_code` IN ($currency_codes_in)";
$stmt = $db->prepare($query);
$stmt->execute($currency_codes);
$arr = $stmt->fetchAll(PDO::FETCH_KEY_PAIR);