Diskuze: PHP/MySQL insert a vrácení vloženého autoincrement ID
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.
Člen
Zobrazeno 6 zpráv z 6.
//= 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.
Na funkce začínající mysql_ zapomeň. PDO má metodu lastInsertId(). Na metodu si dej pozor při práci s transakcemi, na ID se musíš ptát před commitnutím.
Vzhledem k tomu, že jsem to psal 2x z důvodu odhlášení, tak jsem něco
málo vynechal. Jako takhle vím, že míchat to nemohu, spíše jsem to uvedl,
že jsem našel funkci, která by mohla řešit mojí situaci.
lastInsertID() jsem v PDO našel, ale díky tomuto jsem usoudil, že mi to najde
poslední ID a nikoliv přesně to vkládané. Nebo je ten název jen trošku
matoucí? Teoreticky jestli že to najde poslední ID i když v několika ms,
tak by se mohlo vložit jiné ID a mohlo by to znamenat docela kritické
problémy.
Funkce vrátí ID posledního záznamu, který si vložil. Tedy pokud vložíš jen jeden záznam, tak ti vrátí ID toho záznamu. Pokud by si vkládal 3 záznamy, tak vrátí ID třetího záznamu atd.
Tak to je pak přesně co potřebuji, zmátl mě název takže jsem to pak už ani nezkoušel a řekl jsem si že v době co budu v práci, že mi zde někdo poradí. Takhle až aspoň přijdu z práce, tak nemusím hledat, spekulovat a mohu se rovnou vrhnout do řešení.
Děkuji
Přidávám jen způsob řešení.
//Dotaz na poslední ID
public static function getLastId()
{
return self::$spojeni->lastInsertId();
}
Provede se jen dotaz
Zobrazeno 6 zpráv z 6.