PHP Mysql Gün, Ay, Yıl Olarak Veri Çekme
Mysql'deki tablonuzu datetime formatında oluşturmuş olmanız gerekli. Eğer veriler bu şekilde depolanmışsa alttaki gruplama ve mysql'in week, month year fonksiyonlarını inceleyebilirsiniz.
SELECT COUNT(id), EXTRACT(MONTH FROM tarih), EXTRACT(YEAR FROM tarih) FROM bloggirdileri GROUP BY EXTRACT(YEAR_MONTH FROM tarih)
alttaki tarihlerden 5. aylardakileri listeleme;
2011-05-06 11:12:13 (<-- bunu)
2012-06-06 13:12:13
2010-02-06 14:52:13
2011-05-06 21:12:13 (<-- bunu)
2001-08-06 16:12:13
2011-09-06 18:12:43
2009-01-06 11:12:13
2012-02-06 12:17:55
2010-03-06 14:15:13
2012-05-06 11:19:23 (<-- ve bunu)
SELECT * FROM tablom WHERE MONTH(tarih_sutunum) = 5
2 tarih arasını listeleme
select * from tablom where tarih_sutunum between '2012-05-01' and '2012-05-31';
Mysql de son 15 günün verisini çekme
SELECT * FROM tabloAdi WHERE tarih BETWEEN DATE_SUB( CURDATE() ,INTERVAL 15 DAY ) AND CURDATE()
Mysql de son bugüne ait verileri çekme
SELECT * FROM tabloAdi WHERE DAY(tarih) = DAY(CURDATE());
Mysql de bu haftaya ait verileri çekme
SELECT * FROM tabloAdi WHERE WEEK(tarih) = WEEK(CURDATE());
Mysql de bu aya ait verileri çekme
SELECT * FROM tabloAdi WHERE MONTH(tarih) = MONTH(CURDATE());
Mysql de son 10 ay ile 5 ay arasındaki tarih aralığına göre veri çekme
select * from tabloAdi where tarih BETWEEN DATE_SUB( CURDATE() ,INTERVAL 10 MONTH ) AND DATE_SUB( CURDATE() ,INTERVAL 5 MONTH )
Geçen ay için ise
MONTH(CURDATE()-INTERVAL 1 MONTH)
Eğer sadece gün, ay, yıl verileri yeterliyse date olarak tutmayı tavsiye ederim,
eğer gün, ay, yıl ve saat de gerekliyse timestamp olarak kaydedilebilir
11 Yorum
Ahmet Kılıvan / 6 yıl önce
Güzel Çalışma - Tebrikler.
ismail / 7 yıl önce
son 1 günün verisini alırken son 24 saat mi kastediliyor yoksa. saat saat 23:59 da bi kayıt eklendi. 00:00 olduğunda o kayıt gün içine girmiyor mu.
murat gülen / 6 yıl önce
merhabalar bu yıl için WHERE YEAR(tarih) = YEAR(CURDATE()); yaptım ama sonuç alamadım nasıl yapabilirim.
admin / 6 yıl önce
veritabanındaki tarih alanınızı date formatına çevirmelisiniz. Kodunuz ancak bu şekilde çalışır.
ali / 6 yıl önce
hocam şu sorgu; SELECT * FROM tabloAdi WHERE DAY(tarih) = DAY(CURDATE()); aynı güne ait farklı aylarında verilerini çekiyor
admin / 6 yıl önce
DAY(CURDATE()) demek ayın hangi günü ise o günü yazdırır. Bugün için 06 gibi. Diğer ayları istemiyorsan, bu gün dogumgünü olanları çekmek gibi bir şey istiyorsan sorgun şu sekilde olmalı: SELECT * FROM tabloAdi WHERE DAY(tarih) = DAY(CURDATE()) and month(tarih) = month(CURDATE())
Sezgin Sevinc / 5 yıl önce
Allah razı olsun çok işime yaradı
Yorumlayan / 5 yıl önce
Yorumunuz Onaylandıktan Sonra Yayınlanacaktır.
Yorumlayan / 5 yıl önce
Yorumunuz Onaylandıktan Sonra Yayınlanacaktır.
Yorumlayan / 3 yıl önce
Yorumunuz Onaylandıktan Sonra Yayınlanacaktır.
Yorumlayan / 3 yıl önce
Yorumunuz Onaylandıktan Sonra Yayınlanacaktır.