Nalezení data konce měsíce za x měsíců – MySQL – Fórum – Programujte.com
 x   TIP: Přetáhni ikonu na hlavní panel pro připnutí webu

Nalezení data konce měsíce za x měsíců – MySQL – Fórum – Programujte.comNalezení data konce měsíce za x měsíců – MySQL – Fórum – Programujte.com

 

Pavelv0
Stálý člen
1. 11. 2014   #1
-
0
-

Zdravím, mám v db uložený nějaký datum v budoucnosti a potřebuju ho prodloužit o několik měsíců, ale vždy tak, abych dostal nejposlednější datum v onom měsíci. Takže když budu mít v db uloženo 2014-12-31 23:59:59 tak po přičtení půl roku chci dostat 2015-06-30 23:59:59. Vymyslel jsem takovouto prasečinu: 

SELECT DATE_FORMAT(LAST_DAY(MAKEDATE(YEAR(NOW()),DAYOFYEAR('2014-12-31 23:59:59') + '28'*'6' )),'%Y-%m-%d 23:59:59')

Inkremetace se dá očekávat tak do 6ti měsíců, proto mohu využít násobení 28. Ale jsem si jistej že to pujde udělat mnohem jednodušejí a rychleji. Celej příkaz pak bude použit v UPDATE a vstupem bude pouze počet měsíců. Dotaz bude volán z php, takže by šlo možná využít jeho funkci strtotime s formátem něco jako "last day of +6 month'. Ale to už bych musel zase provádět dva SQL dotazy.

Nahlásit jako SPAM
IP: 212.79.110.–
Matěj Andrle+1
Grafoman
2. 11. 2014   #2
-
0
-

#1 Pavelv
Načíst v PHP do objektu DATE -> s přípočtem...

strtotime("+".$years, $row["date"])
Nahlásit jako SPAM
IP: 78.136.144.–
Zjistit počet nových příspěvků

Přidej příspěvek

Toto téma je starší jak čtvrt roku – přidej svůj příspěvek jen tehdy, máš-li k tématu opravdu co říct!

Ano, opravdu chci reagovat → zobrazí formulář pro přidání příspěvku

×Vložení zdrojáku

×Vložení obrázku

Vložit URL obrázku Vybrat obrázek na disku
Vlož URL adresu obrázku:
Klikni a vyber obrázek z počítače:

×Vložení videa

Aktuálně jsou podporována videa ze serverů YouTube, Vimeo a Dailymotion.
×
 
Podporujeme Gravatara.
Zadej URL adresu Avatara (40 x 40 px) nebo emailovou adresu pro použití Gravatara.
Email nikam neukládáme, po získání Gravatara je zahozen.
-
Pravidla pro psaní příspěvků, používej diakritiku. ENTER pro nový odstavec, SHIFT + ENTER pro nový řádek.
Sledovat nové příspěvky (pouze pro přihlášené)
Sleduj vlákno a v případě přidání nového příspěvku o tom budeš vědět mezi prvními.
Reaguješ na příspěvek:

Uživatelé prohlížející si toto vlákno

Uživatelé on-line: 0 registrovaných, 10 hostů

 

Hostujeme u Českého hostingu       ISSN 1801-1586       ⇡ Nahoru Webtea.cz logo © 20032024 Programujte.com
Zasadilo a pěstuje Webtea.cz, šéfredaktor Lukáš Churý