Diskuze: SQL 1 query 2 príkazi
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.

Člen

Zobrazeno 18 zpráv z 18.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.
Normálně bych vložil záznam do jedné tabulky a poté bych získal poslední vložené ID (za předpokladu, že používáš PDO). Poté bych vložil záznam do druhé tabulky s tím daným ID, které jsem získal...
$db = new PDO(...);
// První dotaz
$lastId = $db->lastInsertId(); // Získáme ID
// Druhý dotaz s $lastId
Proč zbytečně tahat id, když stačí do obou jen vložit?
Mohla by nastat nesrovnalost, že by se do jedné něco omylem navíc vložilo, pak by se nové ID neshodovaly...
presne na to som myslel to by bol dost problem a nemoze sa stat ze by sa
dvaja uzivatelia rigistrovali v pomerne rovnakom case a nejako by sa tie prikazi
pomiesali? ze by sa najprv vikonal prikaz1 pre uzivatel1 potom prikaz1 pre
uzivatel2 a potom prikaz2 u.1 a p.2 pre u.2 tak by sa tie IDcka vlastne posunuli
ale neviem ci taka moznost moze nastat niesom profik zatial
mno poriesil som to asi takto nejak zatial:
Db::query('
INSERT INTO users (email, password, last_login)
VALUES (?, ?, ?)
', $email , $password, time());
Db::query('
INSERT INTO pilots (ID)
SELECT ID FROM users WHERE email=?
', $email);
otázkov je ci sa tieto 2 prikazi daju zmrštit do jedneho query?
Db::query('INSERT INTO users (email, password, last_login) VALUES (?, ?, ?);INSERT INTO pilots (ID) SELECT ID FROM users WHERE email=?',
$email , $password, time(), $email);
Snad jsem se neupsal, jsem už dost jetej dneska Tímhle eliminuješ tu kolizi.
// Tady už by měla být patrná zbytečnost toho selectu
skusal som to tak ale vyhodilo mi error nechapem preco mozno som vynechal
nejaku .,' alebo iny kravinec este to skusim
Ještě to lze řešit triggerem
Něco jako
CREATE TRIGGER nazev AFTER INSERT ON tabulka FOR EACH ROW
BEGIN:
INSERT INTO pilots (id) VALUES (NEW.id_z_prvni_tabulky);
END;
ono je to tak ze to mvc v ktorom to robim tie chyby zachytava nejako vlastnym spôsobom a teraz mi nevypise ziadnu hlasku iba ze je tam chyba keby bola v PHP tak myslim ze by tam nieco napisalo a bez hlasky mi to ukazuje zvycajne vtedy ked spravim chybu v SQL prikaze.
Zobrazeno 18 zpráv z 18.