Mengetahui Nama Hari pada Tanggal Tertentu dengan PHP
July 28th, 2008 | by rosihanari |
Cetak Artikel Ini
Pada artikel ini akan dibahas mengenai cara pembuatan script PHP untuk menampilkan nama hari pada tanggal tertentu. Sebagai contoh misalkan diberikan suatu tanggal 11 September 2001, nah kita ingin mengetahui hari apakah itu? OK kita akan segera mengetahuinya dengan script PHP yang akan kita buat.
Dalam PHP belum ada suatu perintah langsung untuk mengetahui nama hari pada tanggal tertentu. Untuk itu kita harus membuat scriptnya sendiri.
Sebagai pendahuluan, terlebih dahulu saya kenalkan dengan suatu function dalam PHP untuk menampilkan nama hari pada current date (tanggal saat ini). Function ini adalah:
date("l");
dengan parameter l (L kecil) merupakan format specifier untuk menampilkan nama hari. Sedangkan date() sendiri adalah function untuk memperoleh current date. Sehingga apabila diberikan script berikut ini
<?php
echo date("l");
?>
akan menghasilkan output Monday (dengan asumsi tanggal pada saat menjalankan script adalah tanggal 28 Juli 2008).
Lantas bagaimana jika ingin menampilkan hari pada tanggal tertentu? Sabar… kita membuat cara lain untuk mengakalinya.
Dalam PHP, kita bisa menampilkan nama hari pada n hari ke depan atau ke belakang setelah hari ini (current date), yaitu dengan menggunakan function mktime(). Contoh:
<?php
// menampilkan nama hari pada 2 hari ke depan
$x = mktime(0, 0, 0, date("m"), date("d")+1, date("Y"));
echo date("l", $x);
// menampilkan nama hari pada 5 hari sebelumnya
$x = mktime(0, 0, 0, date("m"), date("d")-5, date("Y"));
echo date("l", $x);
?>
Sehingga dari keterangan di atas, dapat disimpulkan bahwa untuk mendapatkan nama hari pada tanggal tertentu dengan menggunakan mktime() kita harus tahu terlebih dahulu selisih hari antara tanggal tertentu tersebut dengan tanggal pada hari ini (current date). Dengan demikian rumus umum mktime() nya adalah
mktime(0, 0, 0, date("m"), date("d")+n, date("Y"));
Yang menjadi pertanyaan sekarang adalah, bagaimana cara menentukan selisih hari antara current date dengan tanggal tertentu, jika tanggal tersebut sudah diketahui? Nah… kita manfaatkan saja query SQL sebagai mana yang telah dibahas pada artikel PHP tentang Pencarian Selisih Waktu.
Berdasarkan logika di atas, sudah dapat kita buat script untuk menampilkan nama hari pada tanggal tertentu.
<?php
mysql_connect("namahost","dbuser","dbpass");
mysql_select_db("dbname");
$tanggal = "2001-09-11"; // tgl yang akan dicari nama harinya
$query = "SELECT datediff('$tanggal', CURDATE()) as selisih";
$hasil = mysql_query($query);
$data = mysql_fetch_array($hasil);
$selisih = $data['selisih'];
$x = mktime(0, 0, 0, date("m"), date("d")+$selisih, date("Y"));
echo date("l", $x);
?>
dengan CURDATE() adalah function dalam SQL untuk mendapatkan current date.
Setelah script di atas dijalankan, akan diperoleh nama hari pada tanggal 11 september 2001 adalah hari Tuesday (dalam bhs Inggris). Sekarang bagaimana jika menginginkan output nama harinya dalam bahasa Indonesia? Ya… tinggal gunakan IF saja
<?php
mysql_connect("namahost","dbuser","dbpass");
mysql_select_db("dbname");
$tanggal = "2001-09-11"; // tgl yang akan dicari nama harinya
$query = "SELECT datediff('$tanggal', CURDATE()) as selisih";
$hasil = mysql_query($query);
$data = mysql_fetch_array($hasil);
$selisih = $data['selisih'];
$x = mktime(0, 0, 0, date("m"), date("d")+$selisih, date("Y"));
$namahari = date("l", $x);
if ($namahari == "Sunday") $namahari = "Minggu";
else if ($namahari == "Monday") $namahari = "Senin";
else if ($namahari == "Tuesday") $namahari = "Selasa";
else if ($namahari == "Wednesday") $namahari = "Rabu";
else if ($namahari == "Thursday") $namahari = "Kamis";
else if ($namahari == "Friday") $namahari = "Jumat";
else if ($namahari == "Saturday") $namahari = "Sabtu";
echo $namahari;
?>
Mudah bukan membuatnya?
Beberapa artikel terkait
- Mencari Selisih Hari dari Dua Buah Tanggal dengan PHP (Tanpa Query SQL)
- Menghitung Jumlah Hari Minggu Antara Dua Tanggal
- Script PHP untuk Mencari Selisih Waktu dan Tanggal
- Mencari Jumlah Hari dalam Bulan Tertentu
- Mencari Selisih Waktu dan Tanggal dengan SQL
- Script PHP Mencari Usia Seseorang
- Menampilkan Pesan Teks Pada Postingan Wordpress Berkategori Tertentu
- Editing Data Tanggal via Form dengan PHP
- Mengetahui Kinerja Script PHP Berdasarkan Waktu Eksekusi
- Teknik Memvalidasi Input Tanggal dengan PHP
Share this article on:
Kata kunci: PHP -
Pertama di Indonesia: "Murottal Al Qur'an + Terjemahan" dalam bentuk CD MP3 Original (
Rosihan Ari adalah seorang programmer, penulis buku, trainer, peneliti dan berusaha menjadi seorang blogger sejati dengan memberikan yang terbaik buat negeri ini. Berfokus pada computer programming serta computer aided learning for mathematics, ia ingin berbagi ilmu yang dimilikinya. 


wah… thanks banyak bos… sangat membantu bgt tuh..
mas bisa kasi tahu bagaimana cara untuk mencari nama hari dengan tanggal, bulan, dan tahun di input oleh user dalam bahasa c++
makasih banyak mas, saya juga sangat terbantu sekali dengan adanya artikel ini…
mas kalo databasenya pake access gimana yang menggunakan odbc,,,,,,,,thanks sebelum dan sesudahnya.
to syam: wah belum pernah eksperimen mas, kalo toh gak bisa… ya terpaksa harus scripting di PHP nya
saya akan coba neh script,,,,,terima kasih banyak Mas…!!