Diskuze: Výber najvyššieho možného čísla z tabuľky
V předchozím kvízu, Online test znalostí SQL a databází, jsme si ověřili nabyté zkušenosti z kurzu.
Tvůrce
Zobrazeno 7 zpráv z 7.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí SQL a databází, jsme si ověřili nabyté zkušenosti z kurzu.
Z té chyby je to patrné - Poddotaz vrací více než jednu hodnotu.
asi bych nevolil "not between", ale "NOT IN", nicméně není mi z toho tvého
dotazu zcela jasné, čeho chceš dosáhnout.
Mimochodem snažit se nacpat vše do jednoho dotazu nemusí být vždy ideální
řešení...
problému rozumiem, len ho neviem vyriešiť
hneď ráno skúsim not in a skúsim to aj vysvetliť
v podstate v tabuľke kde sú rezervácie mám stĺpce
[ID] [int] IDENTITY(1,1) NOT NULL,
[PLANT_ID] [int] NULL,
[PROFILE_TYPE] [nvarchar](50) NULL,
[NO_FROM] [int] NULL,
[NO_TO] [int] NULL
Plant_id obsahuje ID spolocnosti ktore je z tabulky spolocnosti,
Profile_type obsahuje typ profilu, zatial vzdy 'A'
No_from je zaciatok rezervacie
No_to je koniec rezervacie
ked ma spolocnost rezervaciu nemam problem vygenerovat cislo,
ale ked spolocnost nema rezervaciu potrebujem generovat vzdy najnizsie mozne
cislo, ale nesmie byt v rezervacii,
uz som to nejako dal dokopy, ale stale to nieje ono
potrebujem sa pozriet do tabulky rezervacii a zistit ci vygenerovane cislo nieje
v ktorom kolvek rozsahu
dufam ze som to vysvetlil dobre
Pořád nějak nechápu, jaké číslo to vlastně chceš generovat?
a spoločnosť B ktorá nieje v rezervácii dostane najvyššie možné číslo mimo čísiel ktoré sú rezervované,
ale ked spolocnost nema rezervaciu potrebujem generovat vzdy najnizsie mozne cislo, ale nesmie byt v rezervacii,
Mezi pojmy nejvyšší a nejnižší je jistý jemný rozdíl. Následující script je pro nejvyšší číslo:
-- vybere minimum ze dvou cisel ve vysledku subquery
SELECT
drawing_no = MIN(drawing_no)
FROM (
-- vybere nejnizsi cislo, ktere je v nejake rezervaci
-- nebo nic, pokud neexistuje rezervace
SELECT
drawing_no = MIN(drawing_no)
FROM
drawings1 AS d
INNER JOIN drawing_no_reservations AS r ON
r.profile_type = 'A'
AND
r.plant_id = 1
AND
d.drawing_no + 1 BETWEEN r.no_from AND r.no_to
WHERE
d.drawing_type = 'A'
UNION ALL
-- vybere nejvyssi cislo, ktere neni v zadne rezervaci
SELECT
drawing_no = MAX(drawing_no)
FROM
drawings1 AS d
LEFT OUTER JOIN drawing_no_reservations AS r ON
r.profile_type = 'A'
AND
d.drawing_no + 1 BETWEEN r.no_from AND r.no_to
WHERE
d.drawing_type = 'A'
AND
r.ID IS NULL
) AS q
Zřejmě špatně chápeš operátor BETWEEN. Ten testuje, jestli nějaká
hodnota je v rozsahu daném počáteční a koncovou hodnotou. Např.
2 BETWEEN 1 AND 3 = true
4 BETWEEN 1 AND 3 = false
Zobrazeno 7 zpráv z 7.