Menghitung Usia Dengan Akurat - MySQL Dasar #26


Dalam MySQL/MariaDB Anda bisa menghitung sebuah nilai usia seseorang dari sebuah string tanggal secara akurat. Secara sederhana untuk menghitung usia kita hanya melakukan operasi pengurangan (tanggal sekarang - tanggal lahir = usia) tetapi itu masih belum akurat terutama ketika bulan/tanggal sekarang belum lebih besar dari bulan/tanggal lahir

 Daftar Isi : Tanggal dan Waktu – MySQL Dasar #14 

Demonstrasi sederhana bagaimana menghitung nilai umur seseorang dari sebuah variabel temporer yang berisi string tanggal


MariaDB [root93]> SELECT @sekarang, @lahir, YEAR(@sekarang)-YEAR(@lahir)-IF(RIGHT('@sekarang',5)<RIGHT('@lahir',5),1,0) AS usia,
    -> MID(@sekarang,6,2) AS 'Bulan Sekarang', MID(@lahir,6,2) AS 'Bulan Lahir',
    -> MID(@sekarang,6,2)-MID(@lahir,6,2) AS 'Rentang Bulan';
+------------+------------+------+----------------+-------------+---------------+
| @sekarang  | @lahir     | usia | Bulan Sekarang | Bulan Lahir | Rentang Bulan |
+------------+------------+------+----------------+-------------+---------------+
| 2022-05-11 | 1993-07-30 |   28 | 05             | 07          |            -2 |
+------------+------------+------+----------------+-------------+---------------+
1 row in set (0.00 sec)


Selanjutnya formula diatas perlu dicoba dengan terlebih dahulu membuah sebuah tabel teman seperti berikut ini

MariaDB [root93]> CREATE TABLsE teman(nama VARCHAR(30), lahir DATE);
Query OK, 0 rows affected (0.69 sec)

MariaDB [root93]> INSERT INTO teman (nama, lahir) VALUES('Adi','1994-02-01');
Query OK, 1 row affected (0.09 sec)

MariaDB [root93]> INSERT INTO teman (nama, lahir) VALUES('Nanang','1995-07-11');
Query OK, 1 row affected (0.08 sec)

MariaDB [root93]> INSERT INTO teman (nama, lahir) VALUES('Wawan','1991-05-12');
Query OK, 1 row affected (0.03 sec)

MariaDB [root93]> INSERT INTO teman (nama, lahir) VALUES('Ani','1993-08-12');
Query OK, 1 row affected (0.08 sec)

Selanjutnya Anda bisa menghitung nilai usia pada tabel teman diatas dengan parameter seperti berikut

MariaDB [root93]> SELECT nama, lahir, CURDATE() AS 'Tanggal Sekarang', YEAR(CURDATE())-YEAR(lahir)
    -> -IF(RIGHT('CURDATE()',5)<RIGHT('lahir',5),1,0) AS umur FROM teman;
+--------+------------+------------------+------+
| nama   | lahir      | Tanggal Sekarang | umur |
+--------+------------+------------------+------+
| Adi    | 1994-02-01 | 2022-05-11       |   27 |
| Nanang | 1995-07-11 | 2022-05-11       |   26 |
| Wawan  | 1991-05-12 | 2022-05-11       |   30 |
| Ani    | 1993-08-12 | 2022-05-11       |   28 |
+--------+------------+------------------+------+
4 rows in set (0.00 sec)

Kemudian misalnya Anda ingin membandingkan antara suatu string tanggal untuk mencari perbedaaan antara satu dengan yang lainnya. Misalnya disini kita ingin mengetahui berapa umur 3 orang teman lainnya ketika Nanang dilahirkan

MariaDB [root93]> select nama, lahir, '1995-07-11' AS 'Tanggal Lahir Nanang',
    -> YEAR('1995-07-11')-YEAR(lahir)
    -> -IF(RIGHT('1995-07-11',5) < RIGHT('lahir',5),1,0) AS 'Usia' FROM teman WHERE nama !='Nanang';
+-------+------------+----------------------+------+
| nama  | lahir      | Tanggal Lahir Nanang | Usia |
+-------+------------+----------------------+------+
| Adi   | 1994-02-01 | 1995-07-11           |    0 |
| Wawan | 1991-05-12 | 1995-07-11           |    3 |
| Ani   | 1993-08-12 | 1995-07-11           |    1 |
+-------+------------+----------------------+------+
3 rows in set (0.00 sec)

Menghitung usia dalam satuan bulan

MariaDB [root93]> SELECT nama, lahir, CURDATE() AS 'Hari ini',
    -> (YEAR(CURDATE())-YEAR(lahir)) * 12 - IF(MONTH(CURDATE()) <  MONTH(lahir),1,0) AS 'Usia Dalam Bulan' FROM teman
+--------+------------+------------+------------------+
| nama   | lahir      | Hari ini   | Usia Dalam Bulan |
+--------+------------+------------+------------------+
| Adi    | 1994-02-01 | 2022-05-13 |              336 |
| Nanang | 1995-07-11 | 2022-05-13 |              323 |
| Wawan  | 1991-05-12 | 2022-05-13 |              372 |
| Ani    | 1993-08-12 | 2022-05-13 |              347 |
+--------+------------+------------+------------------+
4 rows in set (0.00 sec)
         

Perhitungan menghitung usia dalam satuan bulan diatas masih belum belum akurat, contohnya disana bahwa Ani lahir pada bulan 8 dan bulan sekarang adalah bulan 5, sehingga bukan 347 bulan ataupun 348 bulan, karena masih kurang 3 bulan lagi, sehingga sehingga hitungannya adalah ((tahun sekarang - tahun lahir)) * 12 + ((bulan sekarang - bulan lahir)) - (jika hari ini lebih kecil < dari hari lahir, maka dikurangi 1, tapi jika tidak dikurang 0). Sehingga parameternya akan menjadi seperti berikut

       MariaDB [root93]> SELECT nama, lahir, CURDATE() AS 'Hari ini',
    -> (YEAR(CURDATE())-YEAR(lahir)) * 12 +(MONTH(CURDATE())-MONTH(lahir))- IF(DAYOFMONTH(CURDATE()) <  DAYOFMONTH(lahir),1,0) AS 'Usia Dalam Bulan'
    -> FROM teman;
+--------+------------+------------+------------------+
| nama   | lahir      | Hari ini   | Usia Dalam Bulan |
+--------+------------+------------+------------------+
| Adi    | 1994-02-01 | 2022-05-13 |              339 |
| Nanang | 1995-07-11 | 2022-05-13 |              322 |
| Wawan  | 1991-05-12 | 2022-05-13 |              372 |
| Ani    | 1993-08-12 | 2022-05-13 |              345 |
+--------+------------+------------+------------------+
4 rows in set (0.02 sec)

 

 Menghitung Usia Secara Lengkap Dalam Satuan Hari, Bulan dan Tahun

Selanjutnya Saya akan memberikan contoh bagaimana menghitung umur/usia seseorang dengan menampilkan hari lahir, menampilkan dalam hitungan hari, bulan dan tahun.


MariaDB [root93]> SELECT nama, lahir, CURDATE() AS 'Hari ini',
    -> DAYNAME(lahir) AS 'hari lahir',
    -> (YEAR(CURDATE())-YEAR(lahir)) * 12 +(MONTH(CURDATE())-MONTH(lahir))
    -> - IF(DAYOFMONTH(CURDATE()) <  DAYOFMONTH(lahir),1,0) AS 'Usia Dalam Bulan',
    -> (YEAR(CURDATE())-YEAR(lahir)) * 365 +(DAYOFYEAR(CURDATE())-DAYOFYEAR(lahir)) AS 'Usia dalam hari',
    -> YEAR(CURDATE())-YEAR(lahir) - IF(RIGHT(CURDATE(),5)<RIGHT(lahir,5),1,0) AS 'usia'
    -> FROM teman;
+--------+------------+------------+------------+------------------+-----------------+------+
| nama   | lahir      | Hari ini   | hari lahir | Usia Dalam Bulan | Usia dalam hari | usia |
+--------+------------+------------+------------+------------------+-----------------+------+
| Adi    | 1994-02-01 | 2023-01-13 | Tuesday    |              347 |           10566 |   28 |
| Nanang | 1995-07-11 | 2023-01-13 | Tuesday    |              330 |           10041 |   27 |
| Wawan  | 1991-05-12 | 2023-01-13 | Sunday     |              380 |           11561 |   31 |
| Ani    | 1993-08-12 | 2023-01-13 | Thursday   |              353 |           10739 |   29 |
+--------+------------+------------+------------+------------------+-----------------+------+
4 rows in set (0.00 sec)

Menghitung Usia Dalam Satuan Hari, Bulan Beserta Selisihnya

Baca juga : Menghitung Usia Pertanggal Tertentu MySQL

Selanjutnya setelah bisa menampilkan hitungan umur dalam satuan hari dan bulan, Anda juga bisa menghitung berapa selisih/rentang/interval hari atau bulan, antara hari/bulan sekarang dengan hari/bulan lahir dengan rumus :

  1. Rumus menghtiung selisih bulan = bulan sekarang - bulan lahir 
  2. Rumus menghitung selish hari = nomor hari sekarang - nomor hari lahir
Nantinya selesih akan menghasilkan nilai positif atau negatif, jika negatif maka bulan atau harinya masih kurang, jika positif maka nilainya sudah lebih dari bulan/hari lahir. Dimana Anda perlu menghitung panjang bulan dan panjang hari dalam setahun

 Untuk lebih jelasnya perhatikan contoh berikut


MariaDB [root93]> SELECT nama, lahir, CURDATE() AS 'Hari ini',
    -> DAYNAME(lahir) AS 'hari lahir',
    -> (YEAR(CURDATE())-YEAR(lahir)) * 12 +(MONTH(CURDATE())-MONTH(lahir))
    -> - IF(DAYOFMONTH(CURDATE()) <  DAYOFMONTH(lahir),1,0) AS 'Usia Dalam Bulan',
    -> CONCAT(MONTH(CURDATE())-MONTH(lahir),' bulan') AS 'Selisih Bulan',
    -> CONCAT(DAYOFYEAR(CURDATE())-DAYOFYEAR(lahir),' hari') AS 'Selisih Hari',
    -> (YEAR(CURDATE())-YEAR(lahir)) * 365 +(DAYOFYEAR(CURDATE())-DAYOFYEAR(lahir)) AS 'Usia dalam hari',
    -> YEAR(CURDATE())-YEAR(lahir) - IF(RIGHT(CURDATE(),5)<RIGHT(lahir,5),1,0) AS 'usia'
    -> FROM teman;
+--------+------------+------------+------------+------------------+---------------+--------------+-----------------+------+
| nama   | lahir      | Hari ini   | hari lahir | Usia Dalam Bulan | Selisih Bulan | Selisih Hari | Usia dalam hari | usia |
+--------+------------+------------+------------+------------------+---------------+--------------+-----------------+------+
| Adi    | 1994-02-01 | 2023-01-13 | Tuesday    |              347 | -1 bulan      | -19 hari     |           10566 |   28 |
| Nanang | 1995-07-11 | 2023-01-13 | Tuesday    |              330 | -6 bulan      | -179 hari    |           10041 |   27 |
| Wawan  | 1991-05-12 | 2023-01-13 | Sunday     |              380 | -4 bulan      | -119 hari    |           11561 |   31 |
| Ani    | 1993-08-12 | 2023-01-13 | Thursday   |              353 | -7 bulan      | -211 hari    |           10739 |   29 |
+--------+------------+------------+------------+------------------+---------------+--------------+-----------------+------+
4 rows in set (0.00 sec)

Anda juga bisa menggunakan TO_DAYS untuk menghitung interval umur yang nantinya akan ditampilkan dalam hitungan hari


MariaDB [root93]> SELECT nama, lahir, CURDATE() AS 'Hari ini',
    -> (YEAR(CURDATE())-YEAR(lahir)) * 12 +(MONTH(CURDATE())-MONTH(lahir))
    -> - IF(DAYOFMONTH(CURDATE()) <  DAYOFMONTH(lahir),1,0) AS 'Usia Dalam Bulan',
    -> FLOOR(((TO_DAYS(CURDATE()) - TO_DAYS(lahir)))/7) AS 'Usia Minggu',
    -> (TO_DAYS(CURDATE())) - TO_DAYS(lahir) AS 'Usia dalam hari',
    -> YEAR(CURDATE())-YEAR(lahir) - IF(RIGHT(CURDATE(),5)<RIGHT(lahir,5),1,0) AS 'usia'
    -> FROM teman;
+--------+------------+------------+------------------+-------------+-----------------+------+
| nama   | lahir      | Hari ini   | Usia Dalam Bulan | Usia Minggu | Usia dalam hari | usia |
+--------+------------+------------+------------------+-------------+-----------------+------+
| Adi    | 1994-02-01 | 2023-01-13 |              347 |        1510 |           10573 |   28 |
| Nanang | 1995-07-11 | 2023-01-13 |              330 |        1435 |           10048 |   27 |
| Wawan  | 1991-05-12 | 2023-01-13 |              380 |        1652 |           11569 |   31 |
| Ani    | 1993-08-12 | 2023-01-13 |              353 |        1535 |           10746 |   29 |
+--------+------------+------------+------------------+-------------+-----------------+------+
4 rows in set (0.00 sec)

Alternatif lain untuk menghitung usia dalam bulan Anda juga bisa menggunakan PERIOD_DIFF seperti berikut


MariaDB [root93]> SELECT nama, lahir, PERIOD_DIFF(DATE_FORMAT(NOW(),'%Y%m'),DATE_FORMAT(lahir,'%Y%m')) AS bulan
    -> FROM teman;
+--------+------------+-------+
| nama   | lahir      | bulan |
+--------+------------+-------+
| Adi    | 1994-02-01 |   347 |
| Nanang | 1995-07-11 |   330 |
| Wawan  | 1991-05-12 |   380 |
| Ani    | 1993-08-12 |   353 |
+--------+------------+-------+
4 rows in set (0.00 sec)

atau juga menghitungnya melalui DATEDIF


MariaDB [root93]> SELECT nama, lahir, (DATEDIFF(CURDATE(), lahir) DIV 30) AS bulan_terlewati FROM teman;
+--------+------------+-----------------+
| nama   | lahir      | bulan_terlewati |
+--------+------------+-----------------+
| Adi    | 1994-02-01 |             352 |
| Nanang | 1995-07-11 |             335 |
| Wawan  | 1991-05-12 |             385 |
| Ani    | 1993-08-12 |             358 |
+--------+------------+-----------------+
4 rows in set (0.00 sec)

Jika ingin menghitung bulan yang sudah terlewati dari tanggal lahir dari tahun sebelumnya, Anda bisa melihat contoh berikut :


MariaDB [root93]> SELECT CURDATE() AS sekarang,DATE_FORMAT(CURDATE(),('1993-07-30')) AS tgl_lahir,
    -> PERIOD_DIFF(DATE_FORMAT(NOW(),'%Y%m'),'202207') AS bulan_terlewati;
+------------+------------+-----------------+
| sekarang   | tgl_lahir  | bulan_terlewati |
+------------+------------+-----------------+
| 2023-01-13 | 1993-07-30 |               6 |
+------------+------------+-----------------+
1 row in set (0.00 sec)

atau Untuk mengetahui bulan yang terlewat dari tahun sebelumnya (tahun ini) berdasarkan tgl lahir Anda, Anda dapat menambahkan kondisi di dalam query Anda yang akan mengecek apakah tahun lahir sama dengan tahun sekarang. Jika sama, maka hanya perlu menghitung perbedaan bulan antara bulan lahir dan bulan saat ini. Jika tidak sama, maka harus dihitung perbedaan bulan antara bulan lahir dan bulan saat ini ditambah 12 bulan (1 tahun).


MariaDB [root93]> SELECT nama, lahir,
    -> CASE
    -> WHEN YEAR(lahir) = YEAR(CURDATE()) THEN MONTH(CURDATE())-MONTH(lahir)
    -> ELSE MONTH(CURDATE())-MONTH(lahir)+12
    -> END AS bulan_terlewati
    -> FROM teman;
+--------+------------+-----------------+
| nama   | lahir      | bulan_terlewati |
+--------+------------+-----------------+
| Adi    | 1994-02-01 |              11 |
| Nanang | 1995-07-11 |               6 |
| Wawan  | 1991-05-12 |               8 |
| Ani    | 1993-08-12 |               5 |
+--------+------------+-----------------+
4 rows in set (0.00 sec)

Baca selanjutnya : Menggeser Tanggal dan Waktu - MySQL Dasar #27

0 Response to "Menghitung Usia Dengan Akurat - MySQL Dasar #26"

Post a Comment

Komentar yang Anda kirim akan terlebih dahulu di moderasi oleh Admin