• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Wybranie najbliższej daty SQL

Hosting forpsi easy 1 pln
0 głosów
241 wizyt
pytanie zadane 23 listopada 2022 w SQL, bazy danych przez UczenVadera Początkujący (380 p.)
Witam!
Posiadam bazę danych, w której zapisuję daty. Chciałbym wybrać rekord, który jest najbliższy danemu dniu. Szukałem i nie znalazłem konkretnych odpowiedzi, bądź istniejące rozwiązania problemów nie za dobrze działały u mnie.

Formatowanie daty: date('Y-m-d H:i:s')

Przykład:

W bazie danych mam wpisane
2022-11-22 -> Dziś jest 23 nie pokażę tego rekordu
2022-11-23 -> Dziś jest 23 nie pokażę tego rekordu
2022-11-24 -> Dziś jest 23 więc pokażę ten rekord.
2022-11-25 -> Dziś jest 23 nie pokażę tego rekordu, ale pokażę go jak będzie 24

z góry dziękuję za pomoc.
komentarz 23 listopada 2022 przez Oscar Nałogowiec (29,130 p.)

@UczenVadera,  Trzeba bardziej sprecyzować pojęcie "najbliższy dzien". Czas się trochę dziwnie liczy - od wtorku do czwartku są tylko 2 dni, ale od czwartku do wtorku - 5 surprise

Czy chcesz dzien w przeszlości (najnowszy produkt, zdarzenie), czy w przyszłości (umawiasz wizytę u lekarza)? Bo tak najbliższy "dwukierunkowo" to trochę bez sensu.

komentarz 23 listopada 2022 przez UczenVadera Początkujący (380 p.)
Chodzi o to, że po prostu ma wybrać rekord, który ma w sobie datę z najbliższym dniem od aktualnego. Dziś jest 23.11.2022 w bazie mam np. 27.11.2022 i 30.11.20222, to ma jako pierwszy pokazać 27, jeżeli minie 27, to pokaże 30.
komentarz 23 listopada 2022 przez VBService Ekspert (246,010 p.)

Najpierw piszesz, że

2022-11-22 -> Dziś jest 23 nie pokażę tego rekordu
2022-11-23 -> Dziś jest 23 nie pokażę tego rekordu
2022-11-24 -> Dziś jest 23 więc pokażę ten rekord.
2022-11-25 -> Dziś jest 23 nie pokażę tego rekordu, ale pokażę go jak będzie 24

z czego można było wnioskować, że Tobie chodzi o dzień dzisiejszy + 1 dzień

później piszesz

wybrać rekord, który ma w sobie datę z najbliższym dniem od aktualnego. Dziś jest 23.11.2022 w bazie mam np. 27.11.2022 i 30.11.20222, to ma jako pierwszy pokazać 27, jeżeli minie 27, to pokaże 30.

czyli wersja, którą podał @areklipno;  jest IMHO tego czego szukasz.

2 odpowiedzi

+1 głos
odpowiedź 23 listopada 2022 przez areklipno Stary wyjadacz (11,890 p.)
wybrane 25 listopada 2022 przez UczenVadera
 
Najlepsza

Cześć,

a nie wystarczy po prostu założyć limitu na zwracane wiersze? Tzn.

select * 
from tabela
where data_tabela > 'twojadata'
order by data_tabela
limit 1

data_tabela - kolumna z datą w tabeli bazy danych

'twojadata' - interesująca Cię data.

Składnia może się nieco różnić w zależności od silnika bazy danych, ale takie podejście powinno wystarczyć.

komentarz 23 listopada 2022 przez VBService Ekspert (246,010 p.)
edycja 23 listopada 2022 przez VBService

Nie za bardzo bo

where data_tabela > 'twojadata'

"zwróci" wszystkie daty "większe" od podanej, a OP chodzi o podana data + 1 dzień

2022-11-22 -> Dziś jest 23 nie pokażę tego rekordu
2022-11-23 -> Dziś jest 23 nie pokażę tego rekordu
2022-11-24 -> Dziś jest 23 więc pokażę ten rekord.
2022-11-25 -> Dziś jest 23 nie pokażę tego rekordu, ale pokażę go jak będzie 24

komentarz 23 listopada 2022 przez areklipno Stary wyjadacz (11,890 p.)

@VBService - nie do końca...  ponieważ:

- warunek where pokaże wszystkie daty nowsze

- order by ułoży je w kolejności by najmniejsza/najwcześniejsza dostępna data była pierwsza

- limit 1 - pokaże tylko pierwszą (najwcześniejszą) dostępną w zwróconym uszeregowaniu datę.

komentarz 23 listopada 2022 przez VBService Ekspert (246,010 p.)

Ach, tak masz rację przeoczyłem LIMIT 1smiley

0 głosów
odpowiedź 23 listopada 2022 przez VBService Ekspert (246,010 p.)
edycja 23 listopada 2022 przez VBService

Sprawdź: DATE_ADD [ 1 ] [ 2 ]

DATE_ADD(NOW(), INTERVAL 1 DAY)
DATE_ADD('MyDate', INTERVAL 1 DAY)
komentarz 23 listopada 2022 przez UczenVadera Początkujący (380 p.)
To mi nic nie da, bo wyświetli tylko 1 dzień do przodu, potrzebuję wybrać rekord z datą, która jest najbliższa daty aktualnej.

Podobne pytania

0 głosów
2 odpowiedzi 166 wizyt
0 głosów
1 odpowiedź 462 wizyt
pytanie zadane 9 marca 2016 w PHP przez Filip31411 Dyskutant (8,820 p.)
+1 głos
1 odpowiedź 178 wizyt

92,088 zapytań

140,746 odpowiedzi

317,709 komentarzy

61,408 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Akademia Sekuraka 2024 zapewnia dostęp do minimum 15 szkoleń online z bezpieczeństwa IT oraz dostęp także do materiałów z edycji Sekurak Academy z roku 2023!

Przy zakupie możecie skorzystać z kodu: pasja-akademia w koszyku, uzyskując rabat aż -50% (jeszcze tylko dziś 30.11 z okazji Black Week, a potem będzie to 30%) na bilety w wersji "Standard"! Więcej informacji na temat akademii znajdziecie tutaj. Dziękujemy Sekurakowi za tak fajną zniżkę dla Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 15% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...