Cześć, mam tabele ksiazki w której przechowuje ilość wszystkich egzemplarzy danej książki. Gdy książka jest wypożyczana wstawiam jej id oraz kilka innych rzeczy do tabeli wypozyczone. Potrzebuje teraz uzyskać wynik zapytania, ile jest wszystkich egzemplarzy, ile zostało wypożyczonych i ile jeszcze jest możliwych do wypożyczenia. Problemu by nie było, gdyby nie to że w tabeli są tylko te książki które zostały wypożyczone, więc przy lewym połączeniu tabel mam zwracane wartości null zamiast 0. Nie mogę, więc policzyć ile pozostało. Jak wartości null zamienić na zera aby wyniki były prawidłowe?
SELECT ilosc_egzemplarzy,wypozyczonych,ilosc_egzemplarzy-wypozyczonych AS pozostalo
FROM ksiazki k
LEFT JOIN
(SELECT id_ksiazki,COUNT(*) AS wypozyczonych
FROM wypozyczone
GROUP BY id_ksiazki)
AS w
ON w.id_ksiazki = k.id_ksiazki;
+-------------------+---------------+-----------+
| ilosc_egzemplarzy | wypozyczonych | pozostalo |
+-------------------+---------------+-----------+
| 10 | NULL | NULL |
| 15 | 1 | 14 |
| 20 | 2 | 18 |
| 32 | 1 | 31 |
| 80 | NULL | NULL |
| 1 | 1 | 0 |
| 8 | NULL | NULL |
| 8 | NULL | NULL |
| 5 | NULL | NULL |
+-------------------+---------------+-----------+