Diskuze: Zkopírování DATE z databáze do nového řádku v databázi
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.

Člen

Zobrazeno 7 zpráv z 7.
//= 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.
Ahoj, jaký datový typ má sloupec "datum" a jakou hodnotu vypisuje
echo $img["datum"]
?
Případně to stejné můžeš udělat rovnou v jednom SQL dotazu
$id = (int) $_POST["potvrdit"]; // pozor na SQL injection
INSERT INTO xxx (perioda, datum)
SELECT perioda, datum FROM xxx WHERE xxx_id = $id
Datový typ je: Date
Echo vypisuje datum správně, tak jak je v databázi: 2018-03-09
Po Insert Into se uloží jako 0000-00-00
Databázi mám Xampp v phpmyadmin.
Udělat z toho jeden dotaz je zajímavý nápad. To vyzkouším, ale nemyslím, že by to vyřešilo problém.
Tak potvrzuji, že udělat kopírování v jednom SQL dotazu problém s datem vyřešilo. Díky.
Teď už jen vyřešit přičtení periody k datu a bude. Něco jako "DATEADD(month, perioda, datum)" mi nefunguje, to bych chtěl asi moc.
INSERT INTO xxx (perioda, datum)
SELECT perioda, DATEADD(month, perioda, datum) FROM xxx WHERE xxx_id = $id
Možná se mi to jen zdá, ale přijde mi, že špatně v tom SQL dotazu používáš apostrofy pro uvození textu / data. Pokud vkládáš čísla, tak bez apostrofů, texty a data s. Tedy:
INSERT INTO tabulka (a, b) VALUES (10, 50);
INSERT INTO tabulka (a, b) VALUES ('text', 'text'); // v MySQL můžeš použít i apostrofy místo uvozovek
INSERT INTO tabulka (datum) VALUES ('2017-05-04')
Ohledně problému s přidáváním data - osobně znám a používám funkci DATE_ADD() v MySQL. Zapisuje se ve tvaru
DATE_ADD(datum, INTERVAL počet perioda)
tedy např. pokud chci k datu přidat 5 dní, napíšu
DATE_ADD(datum, INTERVAL 5 DAY)
Dominik: Díky za tip. Něco takového bych volil, ale opět to vyžaduje vytáhnout datum do PHP a pak jej nalít zpět - takže by vznikl problém s nulováním data, který se vyřešil použitím jednoho SQL dotazu. Použít DATE_ADD v SQL se ukázalo velmi elegantním.
Martin: Děkuji moc za všechny tipy. Trochu jsem s tím bojoval ale už to šlape. Po kliknutí na tlačítko se řádek zapíše do databáze znovu ale s datem posunutým o počet měsíců daných v periodě. Paráda.
$sql2 = "INSERT INTO xxx (perioda, datum) SELECT perioda, DATE_ADD(datum, INTERVAL perioda MONTH), FROM xxx WHERE xxx_id = '$xid'";
Zobrazeno 7 zpráv z 7.