Přidat otázku mezi oblíbenéZasílat nové odpovědi e-mailemVyřešeno MS SQL dotaz

Potreboval by som pomoct s dotazom
1. tabulka = rodne cislo, meno, priezvisko a podobne
2. tabulka - rodne cislo, typ, hodnota
tabulky su previazane cez rc, 1:N, v druhej tabulke su v podstate rozsirujuce udaje, v stlpci typ je nazov udaju, v stlpci hodnota je jeho hodnota. Napr pre rodne cislo 11111111/1111 moze byt v tbl 2 zapis niekolko riadkov rc, typ , hodnota napr.
ulica-Novotna, tel-123456, heslo- abcdef, email-jaja@ab.sk, ulica_cislo-20, mobil-09012345678 atd atd

Potrebujem vytiahnut z prvej tabulky rc, meno ak v druhej tabulke chyba riadok v type napr. heslo a email, resp. je typ alebo email ale hodnota pre ne je prazdna, teda maju zadanu napr len ulicu a ulica_cislo
polozka v stlpci typ je v podstate lubovolna (podla cislenika) . . .
Mozno to je blbo navrhnuta struktura, ale ja s tym uz nic nespravim . . . a aj toto je v podstate len taka jednorazova zostava.
Musi to byt jeden select, ziaden program alebo makro alebo funkcia, ak by mal niekto napad, tak dik.
Dufam ze som to napisal zrozumitelne.

Jsou zobrazeny jen nové odpovědi. Zobrazit všechny
Předmět Autor Datum
Ano, je to špatný návrh databáze. Pokud máš tabulku, kde máš různé typy dat, pak potřebuješ další ta… nový
Jan Fiala 09.09.2020 08:34
Jan Fiala
DAkujem vsetkym, ako to byva, netreba sa do vsetkeho hned hrnut, treba to nechat chvilu vyhnit, nako… poslední
truhlik 09.09.2020 11:45
truhlik

Ano, je to špatný návrh databáze.
Pokud máš tabulku, kde máš různé typy dat, pak potřebuješ další tabulku, kde bude seznam těch typů (o referenční integritě ani nemluvím).
Pokud budeš mít seznam typů, pak si jednoduše jedním dotazem vypíšeš, vše, co ti chybí v tabulce 2.
Použij LEFT OUTER JOIN

Jinak bys tu tabulku se seznamem musel v tomto dotazu (a ve všech dalších) uměle vytvářet.

select * 
	from (values ('ulica'), ('telefon'), ('email'), ('mobil')) pom (TypDat)

Pak by to mohlo vypadat nejak takto, chybejici typy si dopln.

SELECT tab1.rodne_cislo, tab1.jmeno, tab2.typ, tab2.hodnota
  FROM tab1 
  JOIN (values ('ulica'), ('telefon'), ('email'), ('mobil')) pom (TypDat) on 1=1  -- kartezsky soucin
  LEFT OUTER JOIN tab2 ON tab1.rodne_cislo = tab2.rodne_cislo and pom.TypDat = tab2.Typ
  WHERE tab2.Typ is null

Pokud bys mel tabulku se seznamem typu, pak ji tam das misto toho konstruktu

Zpět do poradny Odpovědět na původní otázku Nahoru