Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: Obliczanie procentowo, ile rekordów jest w jednej tabeli bez rekordów z drugiej
Forum PHP.pl > Forum > Bazy danych > Oracle
taktofon
Witajcie,
mam za zadanie policzyć ile procentowo przedmiotów nie zostało sprzedanych. W tabeli przedmioty mam wszystkie przedmioty, a w tabeli transakcje mam różne transakcje.

Czyli po prostu sprawdzam, których z tabeli Przedmioty, nie ma w tabeli Transakcje.


  1. SELECT count(*) FROM przedmioty
  2. WHERE id_prz NOT IN (SELECT id_prz FROM transakcje)

Powyższy kod zwróci mi liczbę, ile jest takich przedmiotów, ale ja potrzebuję zrobić to procentowo czyli (NIESPRZEDANE / WSZYSTKIE )* 100 tylko jest problem bo poniższy kod nie działa:

  1. SELECT (count(*)/(SELECT count(*)FROM przedmioty))*100 FROM przedmioty
  2. WHERE id_prz NOT IN (SELECT id_prz FROM transakcje)


Ktoś wie dlaczego ?
mmmmmmm
Nier wiem dlaczego. Wiem, że to poniższe działa dobrze (kropka jest bardzo ważna)
  1. SELECT 100.*count(case when t.id_przedmiotu IS NULL then p.id end)/count(DISTINCT p.id) FROM przedmiot p LEFT JOIN transakcje t ON t.id_przedmiotu=p.id;
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2024 Invision Power Services, Inc.