Tietokannassa on päivämäärät merkkijonoina, ei päivämääräkenttinä. Aikoinaan ei ole ajateltu, että joskus pitäisi niiden avulla laskea jotakin.
Miten saisin kätevimmin (mieluiten) php:llä kahden päivämäärän välin, kun VARCHAR-kentissä on esim. 12.3.2021 ja 17.5.2022?
Päivämäärin väli merkkijonosta
18
174
Vastaukset
- Anonyymi
<?php
$date1=date_create("2013-03-15");
$date2=date_create("2013-12-12");
$diff=date_diff($date1,$date2);
?>
https://www.w3schools.com/php/func_date_date_diff.asp- Anonyymi
MIKSI WINDOWS EI TAJUA TALVIAIKAA!
- Anonyymi
Ei toimi. Päivämäärä on väärää muotoa noissa kentissä. On ilmeisesti muokattava niin, että haetaan erikseen vvv, kk ja pv ja sitten saatetaan se tunnistettavaan muotoon?
- Anonyymi
Voi jeesus miten tyhmä sinä olet.
- Anonyymi
Anonyymi kirjoitti:
Voi jeesus miten tyhmä sinä olet.
Ja sinä vielä tyhmempi!
- Anonyymi
PHP:stä en tiedä, mutta TCL:llä se menee näin:
set myDay1 "12.3.2021"
set myDay2 "17.5.2022"
set sec1 [clock scan $myDay1 -format {%d.%m.%Y}]
set sec2 [clock scan $myDay2 -format {%d.%m.%Y}]
echo [expr $sec2 - $sec1]
... - Anonyymi
Tässä törmättiin sellaiseen vastustamattomaan kiusaukseen nostaa Manjaro Linux muiden yläpuolelle, nimittäin BASH SHELL tulkin alaisuudessa kahden päivämäärän välinen aika päivissä selviää tolkuttoman kivuttomasti:
>>> datediff -i "%d.%m.%Y" "12.3.2021" "17.5.2022" -f %d
431
Totta puhuen kyllä datediff -komennon saa asennettua joka ikiseen Linux jakeluun, ellei se kuulu peruskokoonpanoon.
TULOSTUS YKSIKKÖ
%d = päivissä
%w = viikoissa
%m = kuukausina
%Y = vuosina
%H = tunteina
....
t. TURBO URPO - Anonyymi
Siis tietokannassa on varchar-kenttä, jossa on päivämääriä kirjoitettu kysymyksessä esitetyssä muodossa. Ei siis mitään valmiiksi kovakoodattuja arvoja voi käyttää, vaan arvo on otettava tietokannan kentästä. Ei vaan näy toimivan mitkään esimerkit.
Kentän sisällön voi tulostaa OK, mutta kyse on näiden päivämäärien erotuksesta.- Anonyymi
Eli onko sinun ongelma siinä ettet osaa sijoittaa arvoja muuttujan sisällöksi.
Tuossa edellä antamani päiväys voidaan sijoittaa muuttujaan näin:
>>> nyt="17.5.2022";
Nyt sitten lasketaan erotus muuttujaa hyödyntäen näin:
>>> datediff -i "%d.%m.%Y" "12.3.2021" $nyt -f %w
Ja tämähän esimerkki toimii tälläisenaan BASH SHELL tulkin alaisuudessa.
Joo, vaikuttaa sitä että tavoitteesi on lukea tuntemattomasta tietokannasta päiväys ulos, mainitsit PHP -tulkin, eli onko tarkoitus tuntemattomasta tietokannasta siirtää päiväys PHP -koodilla käsiteltäväksi, jos käytät MySQL -tietokantaa MySQL sisältää kahden päivämäärän välisen erotuksen laskemiseen tietokannan omilla komennoilla:
SELECT DATEDIFF("2022-5-17", "2021-3-12");
https://www.w3schools.com/sql/func_mysql_datediff.asp
Tässä jätän tahallani antamatta mallia MySQL keinoista muuttaa käsiteltävää päiväyksen esitysmuotoa.
t. TURBO URPO - Anonyymi
Kurkista esimerkki osoitteesta
https://pastebin.com/vXeaUM0x
Tein yksinkertaisen esimerkin missä tietokannan taulussa on mainitsemasi tekstipäivät ja ne luetaan muuttujiin, käsitellään teksti päiväykseksi ja lopuksi lasketaan erotus. - Anonyymi
Anonyymi kirjoitti:
Eli onko sinun ongelma siinä ettet osaa sijoittaa arvoja muuttujan sisällöksi.
Tuossa edellä antamani päiväys voidaan sijoittaa muuttujaan näin:
>>> nyt="17.5.2022";
Nyt sitten lasketaan erotus muuttujaa hyödyntäen näin:
>>> datediff -i "%d.%m.%Y" "12.3.2021" $nyt -f %w
Ja tämähän esimerkki toimii tälläisenaan BASH SHELL tulkin alaisuudessa.
Joo, vaikuttaa sitä että tavoitteesi on lukea tuntemattomasta tietokannasta päiväys ulos, mainitsit PHP -tulkin, eli onko tarkoitus tuntemattomasta tietokannasta siirtää päiväys PHP -koodilla käsiteltäväksi, jos käytät MySQL -tietokantaa MySQL sisältää kahden päivämäärän välisen erotuksen laskemiseen tietokannan omilla komennoilla:
SELECT DATEDIFF("2022-5-17", "2021-3-12");
https://www.w3schools.com/sql/func_mysql_datediff.asp
Tässä jätän tahallani antamatta mallia MySQL keinoista muuttaa käsiteltävää päiväyksen esitysmuotoa.
t. TURBO URPOSamapa tuo vaikka laittaakin tuon formaatinmuunnoksen mukaan, on siinä sittenkin sovittelua sinne tuntemattomaan ympäristöön, eli:
SELECT DATEDIFF("2022-5-17", "2021-3-12");
tämä erotus lasketaan muotuilut huomioiden näin:
SELECT DATEDIFF(DATE_FORMAT("2022-5-17", "%Y.%m.%d"), DATE_FORMAT( "2021-3-12", "%Y.%m.%d"));
t. TURBO URPO - Anonyymi
Anonyymi kirjoitti:
Samapa tuo vaikka laittaakin tuon formaatinmuunnoksen mukaan, on siinä sittenkin sovittelua sinne tuntemattomaan ympäristöön, eli:
SELECT DATEDIFF("2022-5-17", "2021-3-12");
tämä erotus lasketaan muotuilut huomioiden näin:
SELECT DATEDIFF(DATE_FORMAT("2022-5-17", "%Y.%m.%d"), DATE_FORMAT( "2021-3-12", "%Y.%m.%d"));
t. TURBO URPOEli, nyt muotoilu määrää mikä arvo on kussakin sarakkeessa, välimerkit/erotinmerkit menettävät merkityksensä
- Anonyymi
Niin, epäselvästi siis kerroin.
Päivämäärät on luettu tietokannasta muuttujiin
$row['order_date']
$row['delivery_date']
TIetokannassa nämä ovat VARCHAR(35) muotoisessa kentässä ja kirjoitettuna sisältönä esim. 3.1.2019 ja 15.2.2019, siis kaksi eri kenttää.
Tavoite on saada näiden kenttien välinen aika, esim. $vv vuotta, $kk kuukautta, $ pv päivää.
Ainoa mitä saan aikaiseksi, on virheilmoituksia.
$diff = ($row['delivery_date'] - $row['order_date']);
echo $diff;
-> Notice: A non well formed numeric value encountered in... vaikkakin antaa jonkinlaisen vastauksen.
jne.- Anonyymi
Näin se menee. Nälkä kasvaa syödessä. Osoitteessa
https://pastebin.com/Gyd64nFp
on meitsin viimeisin versio tähän keissiin. Siitä ideaa muokkaamalla löydät melko varmasti ratkaisuja omiin tarpeisiin.
- Anonyymi
Kiitos ja kumarrus, nyt toimi!
Piti vaan tässä opetella vähän muutakin välillä.- Anonyymi
Tuo pastebin -esimerkki on tarkoituksella tehty isommalla siveltimellä jotta sen idea avautuisi ja olisi helpommin muokattavissa omiin tarpeisiin. Toisin sanoen sen voi tiivistää lyhyemmäksi jos se tulee osaksi jotain toistuvia rutiiniajoja.
- Anonyymi
Hyvä oli esimerkki!
Lisäksi piti huomioida ($regex = preg_match...), että voi olla kentissä myös roskaa.- Anonyymi
Noinhan se aina menee. Ensin luodaan systeemi joka toimii tilanteessa kun x on luku ja y on merkkijono. Sitten huokaistaan helpotuksesta valmiin ratkaisun kanssa ja suunnitellaan systeemi tilanteeseen kun x ei olekaan luku ja/tai y ei olekaan merkkijono 🙂
Tämä jälkimmäinen vaihe voi olla jopa hankalampi rasti varsinkin jos ei voida enää vaikuttaa siihen miten tietoja on alun perin käsitelty ja tallennettu.
Mutta, puretaanhan niitä talojakin sillä perusteella että tulisi kalliimmaksi korjailla vanhaa kuin rakentaa perustuksiaan myöten kokonaan uusi.
Ketjusta on poistettu 2 sääntöjenvastaista viestiä.
Luetuimmat keskustelut
Mies, miksi et vaikuta halukkaalta?
Ihmeellistä käytöstä mieheltä. Toki et ole mikään teinipoika enää.1031727- 2101547
Ikävä on häntä
Josta on tullut niin tärkeä ja rakas. Olisinko onnellinen hänen kanssaan. Ne rakastavat silmät jotka mua katsoo aina jos591030Minkä kultakimpaleen
Menetän jos en saa häntä. Joku muu saisi nauttia siitä hellyydestä, huumorista ja intohimosta. Ehkä hän ymmärtää nyt mik311000Terveystalon lääkärit ylilaskuttaneet
Tämän pörriäiset osaavat, laskuttamisen. Terveystalo myöntää asian. https://www.hs.fi/suomi/art-2000011134269.html "K58865En kai koskaan saa sinua
Koska et usko että riitäisit minulle. Olet aina pitänyt itseäsi liian risana ja heikkona. Katkot korkeutesi, ja poraat k51804Helppo selvittää onko oma täällä
Laittaa yhden selvän kysymyksen ja jos kukaan ei osaa vastata, niin oikea ei ole täällä. Saa käyttää vapaasti hyödykse49785Tykkäsit nainen
Aina eniten lähetyssaarnaajassa, muistan miten nautit!😎😚 meidän pitää päästä vielä kokemaan se.36745Kerroppas nyt
M mies, että kenestä sinä oikein tykkäät, niin saadaan tämä asia muillekin selväksi 😉58735The Summit Suomi: Maxie avaa hyytävästä tilanteesta kuvauksissa: "Veri roiskui ja tajusi, että..."
Oletko seurannut The Summit Suomea? Tykkäätkö vai et tai mitä mieltä ylipäätään olet sarjasta? Moni katsoja on kaikonnut5732