Diskuze: Duplicita riadkov pri spoejeni DB
Zobrazeno 5 zpráv z 5.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
Nerozumim tvemu popisu. Nepouzivam MS Access, tak je to mozna tim. Uvedu priklad pro mysql.
tab zakazka - id_zakazka, text (5 radku)
tab dily - id_dil, text (20 radku)
tab zakazka_dily - id_zakazka, id_dil (30 radku, propojovaci tabulka mezi dily a zakazkami)
SELECT * FROM dily -- zobrazi 20 radku
SELECT * FROM zakazka_dily -- zobrazi 30 radku
SELECT * FROM zakazka_dily WHERE id_zakazka=3967 -- zobrazi 3 radky
SELECT a.id_dil, b.*
FROM zakazka_dily a
LEFT JOIN zakazka b ON b.id_zakazka=a.id_zakazka
WHERE a.id_zakazka=3967
-- zobrazi 3 radky, sloupce a.id_dil, b.id_zakazka, b.text (cili detaily o zakazce)
SELECT a.id_dil, b.*
FROM zakazka_dily a
LEFT JOIN zakazka b ON b.id_zakazka=a.id_zakazka
WHERE a.id_zakazka=3967
GROUP BY a.id_zakazka
-- zobrazi 1 radek pro 1 zakazku s id 3967, 1 id_dil (to spis nechces)
SELECT a.id_dil, b.*, GROUP_CONCAT(a.id_dil)
FROM zakazka_dily a
LEFT JOIN zakazka b ON b.id_zakazka=a.id_zakazka
WHERE a.id_zakazka=3967
GROUP BY a.id_zakazka
-- zobrazi 1 radek pro 1 zakazku s id 3967, 3x id_dil oddelene carkou
-- cili zgrupoval jsem to podle id_zakazka a pouzil funkci GROUP_CONCAT
-- nad sloupcem id_dil aby mi sloupec spojila do retezce a oddelila hodnoty carkou.
V MS Access urcite existuje podobna funkce, mozna CONCAT, WS_CONCAT nebo
jinak, jestli chces dolicit prave tohoto.
google = MS Access group concat
Ahoj, velmi pravděpodobně máš jen zle sestavený dotaz. Tipoval bych to na nevhodně zvolený join, který ti násobí řádky (např. relační vazba přes víc klíčů, ale v joinu probádíš vazbu před jeden atribut).
Můžeš sem ten dotaz poslat + ideálně i strukturu té DB?
Ahoj, staci ti takto poslat SQL kod? Niesom moc dobry v accesse ale tento problem by som rad vyriesil.
Su to vlastne 2 tabulke, kde v prvej mam udaj a ked spojim s dalsiou tak tam je to v troch riadkov kedze kazdy riadok obsahuje iny zaznam.
SELECT public_PPI_Repair.protocol, public_PPI_Repair_Itm.stock_id
FROM public_PPI_Repair LEFT JOIN public_PPI_Repair_Itm ON
public_PPI_Repair.repair = public_PPI_Repair_Itm.repair
WHERE (((public_PPI_Repair.protocol)=[Zadaj cislo protokolu]));
Jestli tomu rozumím správně, potřebuješ všechna stock_id "smrsknout" do jednoho pole, asi takhle?
5974979 | 3009-001705, GH96-12724A, GH81-16831A |
Pokud ano, tak MS Access - pokud vím - tohle sám o sobě neumí a musí se řešit pomocí User Defined Function, viz diskuze na StackOverflow, kde se můžeš inspirovat řešením.
Zobrazeno 5 zpráv z 5.