Diskuze: MySQL - INSERT.. SELECT
V předchozím kvízu, Online test znalostí SQL a databází, jsme si ověřili nabyté zkušenosti z kurzu.
Člen
Zobrazeno 11 zpráv z 11.
//= 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.
Podívej se na kapitolu s poddotazy v MySQL seriálu
Jinak kdybys nám vysvětlil co chceš dělat místo těch divných dotazů, tak bych ti i pomohl, ale tohle se mi luštit nechce.
Nezkoušel jsem to, ale mohlo by to fungovat:
INSERT INTO f_photo (f_album_id, name)
SELECT * FROM
(SELECT f_album_id FROM f_album
WHERE f_user_id = '1' AND url = 'albumicko'
LIMIT 0,1
) as album,
(SELECT "fotka1.jpg" UNION ALL
SELECT "fotka2.jpg" UNION ALL
SELECT "fotka3.jpg") as fotka;
To jsem samozřejmě koukal ... ale chybí mi tam, právě jak tam píše Kit, dotaz typu INSERT ... SELECT
INSERT ... SELECT
používám zejména když potřebuji
transakčně vložit více záznamů, protože standardní
INSERT ... VALUES
umí vložit jen jeden záznam.
Kite, jseš geniální. Ten tvůj dotaz funguje přesně jak chci... akorát mu úplně nerozumím. Hodilo by se k těm SQL článkům dopsat UNION, UNION ALL nebo další o kterých ještě ani nevím. Na netu o tom najdu informace buď v angličtině, kde jsou schované v obrovských dotazech, ve kterých se ztrácím a nebo na českých třeba 13 let starých. Díky.
Díky za uznání. Trvalo mi dost dlouho, než jsem na tyto a podobné vychytávky přišel a začal používat SQL jako normální programovací jazyk.
Kite, věděl bys jak do toho ještě zapojit podmínku, podmínku aby se záznam nevytvářel, když už tam takový záznam je, tím myslím záznam, který by měl stejné "f_album_id" a "f_photo.name"? Přičemž f_photo.name nemůže být unikátním sloupcem (ale unikátním ve výběru těch co mají dané "f_album_id")
... nebo možná to udělám úplně jinak... vytáhnu si zapsaná data z DB a porovnám s těmi co chci zapsat, a až pak budu zapisovat... Hold ještě neumím používat SQL jako programovací jazyk :-/
Netestuj to. Pokud tam již data jsou, databáze by to měla odmítnout. Zbytečně to jen zpomaluje
INSERT INTO f_photo (f_album_id, name)
SELECT * FROM
(SELECT f_album_id AS faid FROM f_album
WHERE f_user_id = '1' AND url = 'pokus'
LIMIT 0,1) as faid,
(SELECT 'fotka1.jpg' as faname) as fotka
WHERE NOT EXISTS (SELECT * FROM f_photo WHERE f_album_id = faid AND name = faname);
Tohle funguje jak chci - nevloží to fotku, když tam již existuje takový záznam. Nevím jak do toho ale zapojit UNION/UNION ALL, abych to mohl udělat pro více fotek. Abych negeneroval dotaz pro každou fotku zvlášť.
Zobrazeno 11 zpráv z 11.