Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> [MYSQL]Zapytanie mysql DELETE BUDOWA, pomocy!
kayy
post
Post #1





Grupa: Zarejestrowani
Postów: 112
Pomógł: 1
Dołączył: 3.08.2008

Ostrzeżenie: (0%)
-----


Witam,

potrzebuje zapytania które;

a)Wywala wszystkie rekordy z tabeli kiedy ; mam datę w polu time i w timeto, jeżeli timeto będzie równy, lub mniejszy time wtedy wywalić. Data jest w formacie 5122008(dzień bez zer wiodących, miesiąc bez zer wiodących, pełen rok).



Z góry wielkie dzięki!
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi (1 - 12)
mike
post
Post #2





Grupa: Przyjaciele php.pl
Postów: 7 494
Pomógł: 302
Dołączył: 31.03.2004

Ostrzeżenie: (0%)
-----


Zmień format daty na normalny. Czyli DATE, DATETIME czy jakiś inny TIMESTAMP.
Go to the top of the page
+Quote Post
kayy
post
Post #3





Grupa: Zarejestrowani
Postów: 112
Pomógł: 1
Dołączył: 3.08.2008

Ostrzeżenie: (0%)
-----


Tylko, że wcześniej mam skrypt dodający 60 dni i nie wiem jak inaczej to zapisać w MYSQL (format daty);

  1. INSERT INTO `time` (`id`,`username`,`time`,`timeto`) VALUES ('','$nickname', DATE_FORMAT(CURRENT_DATE(), '%d%m%Y'), DATE_FORMAT(DATE_ADD(CURRENT_DATE(), INTERVAL 60 DAY), '%d%m%Y'))


Ten post edytował kayy 5.12.2008, 15:07:38
Go to the top of the page
+Quote Post
Cezar708
post
Post #4





Grupa: Zarejestrowani
Postów: 1 116
Pomógł: 119
Dołączył: 10.05.2005
Skąd: Poznań

Ostrzeżenie: (0%)
-----


Cytat(kayy @ 5.12.2008, 15:03:08 ) *
Data jest w formacie 5122008(dzień bez zer wiodących, miesiąc bez zer wiodących, pełen rok).


to w takim razie wykonaj małe zadanie i daj mi 100% opowiedź:

zadanie:
Jeżeli timeto = 1112008 to jest to:
a] 1 listopada 2008 roku
b] 11 stycznia 2008 roku
c] nie da się jednoznacznie odpowiedzieć

jeżeli dałeś odpowiedź c] to w takim razie nie ma możliwości rozwiązania Twojego problemu od ręki bez wcześniejszego przepisania dat na normalny format

pozdro
Cezar708

Ten post edytował Cezar708 5.12.2008, 15:10:43
Go to the top of the page
+Quote Post
ddiceman
post
Post #5





Grupa: Zarejestrowani
Postów: 326
Pomógł: 121
Dołączył: 23.07.2008
Skąd: Wrocław

Ostrzeżenie: (0%)
-----


Pisalem Ci juz, ale nie mowiles, ze bez leading zeros byloby tak:
  1. DELETE FROM tabela WHERE STR_TO_DATE(timeto, '%e%c%Y') < CURRENT_DATE();

trzymanie daty bez zer wiodacych jest bezsensowne, bo jak odroznisz, czy 2112008 to 21 stycznia czy 2 listopada?
Testowalem z leading zeros i na pewno dziala:
  1. CREATE TABLE ftest (id int NOT NULL AUTO_INCREMENT PRIMARY KEY, timeto varchar(200));
  2. INSERT INTO ftest VALUES (NULL, '04122008');
  3. SELECT * FROM ftest; DELETE FROM ftest WHERE str_to_date(timeto, '%d%m%Y') < current_date();
  4. SELECT * FROM ftest;


Ten post edytował ddiceman 5.12.2008, 15:12:55
Go to the top of the page
+Quote Post
kayy
post
Post #6





Grupa: Zarejestrowani
Postów: 112
Pomógł: 1
Dołączył: 3.08.2008

Ostrzeżenie: (0%)
-----


#up
W takim razie jak inaczej zapisać
  1. INSERT INTO `time` (`id`,`username`,`time`,`timeto`) VALUES ('','$nickname', DATE_FORMAT(CURRENT_DATE(), '%d%m%Y'), DATE_FORMAT(DATE_ADD(CURRENT_DATE(), INTERVAL 60 DAY), '%d%m%Y'))
aby było z zerami wiodącymi?

Ten post edytował kayy 5.12.2008, 15:15:31
Go to the top of the page
+Quote Post
ddiceman
post
Post #7





Grupa: Zarejestrowani
Postów: 326
Pomógł: 121
Dołączył: 23.07.2008
Skąd: Wrocław

Ostrzeżenie: (0%)
-----


Dokladnie tak, jak jest - to jest z zerami wiodacymi. jakiego typu masz pole timeto?
Go to the top of the page
+Quote Post
kayy
post
Post #8





Grupa: Zarejestrowani
Postów: 112
Pomógł: 1
Dołączył: 3.08.2008

Ostrzeżenie: (0%)
-----


Date, przyjmuje Y.m.d albo Y.d.m, a ja  chcę d.m.Y czyli tak jak wykonuje to zapytanie
  1. $zapytanka = "INSERT INTO `time` (`id`,`username`,`time`,`timeto`) VALUES ('','$nickname', DATE_FORMAT(CURRENT_DATE(), '%d%m%Y'), DATE_FORMAT(DATE_ADD(CURRENT_DATE(), INTERVAL 60 DAY), '%d%m%Y'))";
to timeto i time = 0000-00-00
Go to the top of the page
+Quote Post
Cezar708
post
Post #9





Grupa: Zarejestrowani
Postów: 1 116
Pomógł: 119
Dołączył: 10.05.2005
Skąd: Poznań

Ostrzeżenie: (0%)
-----


Cytat(kayy @ 5.12.2008, 15:12:16 ) *
#up
W takim razie jak inaczej zapisać
  1. INSERT INTO `time` (`id`,`username`,`time`,`timeto`) VALUES ('','$nickname', DATE_FORMAT(CURRENT_DATE(), '%d%m%Y'), DATE_FORMAT(DATE_ADD(CURRENT_DATE(), INTERVAL 60 DAY), '%d%m%Y'))
aby było z zerami wiodącymi?


w zasadzie to część dat mógłbyś przerobić automatycznie, ale jeżeli skypt, który napiszesz trafi na daty nierozwiązywalne (patrz przykłady moje i ddicemana) to będziesz musiał je przepisać... ręcznie... na podstawie innych danych... niestety
Go to the top of the page
+Quote Post
ddiceman
post
Post #10





Grupa: Zarejestrowani
Postów: 326
Pomógł: 121
Dołączył: 23.07.2008
Skąd: Wrocław

Ostrzeżenie: (0%)
-----


trzeba bylo powiedziec, ze jest typu DATE a nie w formacie 'dd.mm.yyyy':
  1. <?php
  2. $zapytanka = "INSERT INTO `time` (`id`,`username`,`time`,`timeto`) VALUES ('','$nickname', CURRENT_DATE(), DATE_ADD(CURRENT_DATE(), INTERVAL 60 DAY))";
  3. ?>

  1. DELETE FROM `time` WHERE timeto < CURRENT_DATE();


Ten post edytował ddiceman 5.12.2008, 15:23:49
Go to the top of the page
+Quote Post
kayy
post
Post #11





Grupa: Zarejestrowani
Postów: 112
Pomógł: 1
Dołączył: 3.08.2008

Ostrzeżenie: (0%)
-----


Wreszcie (IMG:http://forum.php.pl/style_emoticons/default/winksmiley.jpg) Dzięki diceman, poraz enty mi pomogłeś (IMG:http://forum.php.pl/style_emoticons/default/smile.gif)

#edit
Jeszcze jedno pytanie... Jak odjąć od siebie timeto i time, tak aby pisało ile dni mi pozostało...?

Ten post edytował kayy 5.12.2008, 15:36:33
Go to the top of the page
+Quote Post
ddiceman
post
Post #12





Grupa: Zarejestrowani
Postów: 326
Pomógł: 121
Dołączył: 23.07.2008
Skąd: Wrocław

Ostrzeżenie: (0%)
-----


  1. SELECT DATEDIFF(timeto, CURRENT_DATE()) FROM `time`;
Go to the top of the page
+Quote Post
mike
post
Post #13





Grupa: Przyjaciele php.pl
Postów: 7 494
Pomógł: 302
Dołączył: 31.03.2004

Ostrzeżenie: (0%)
-----


DATEDIFF(expr1,expr2)

~kayy zacznij być samodzielny!
Go to the top of the page
+Quote Post

Reply to this topicStart new topic
2 Użytkowników czyta ten temat (2 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Aktualny czas: 2.10.2025 - 19:47