Saya pikir kueri ini akan melakukan apa yang Anda inginkan. Ini menggunakan
(YEAR(CURDATE())*12+MONTH(CURDATE()))
- (YEAR(STR_TO_DATE(join_date, '%d-%m-%Y'))*12+MONTH(STR_TO_DATE(join_date, '%d-%m-%Y'))) -
- 1
untuk mendapatkan jumlah pengalaman sebulan penuh bagi pengguna,
DAY(LAST_DAY(STR_TO_DATE(join_date, '%d-%m-%Y')))
- DAY(STR_TO_DATE(join_date, '%d-%m-%Y'))
+ 1
untuk mendapatkan jumlah hari dalam bulan pertama, dan
DAY(CURDATE())
untuk mendapatkan jumlah hari dalam bulan ini. Hitungan dua hari dijumlahkan dan jika totalnya> 15, 1 ditambahkan ke jumlah bulan penuh mis.
SELECT id
, name
, (YEAR(CURDATE())*12+MONTH(CURDATE())) - (YEAR(STR_TO_DATE(join_date, '%d-%m-%Y'))*12+MONTH(STR_TO_DATE(join_date, '%d-%m-%Y'))) - 1 -- whole months
+ CASE WHEN DAY(LAST_DAY(STR_TO_DATE(join_date, '%d-%m-%Y'))) - DAY(STR_TO_DATE(join_date, '%d-%m-%Y')) + 1 + DAY(CURDATE()) > 15 THEN 1 ELSE 0 END -- broken month
AS months
FROM user
Kita dapat menggunakan ekspresi ini sebagai JOIN
kondisi antara user
dan allowed_exp_range
untuk menemukan semua pengguna yang memiliki pengalaman dalam rentang tertentu:
SELECT u.id
, u.name
, a.starting_exp_months
, a.end_exp_months
FROM user u
JOIN allowed_exp_range a
ON (YEAR(CURDATE())*12+MONTH(CURDATE())) - (YEAR(STR_TO_DATE(u.join_date, '%d-%m-%Y'))*12+MONTH(STR_TO_DATE(u.join_date, '%d-%m-%Y'))) - 1
+ CASE WHEN DAY(LAST_DAY(STR_TO_DATE(u.join_date, '%d-%m-%Y'))) - DAY(STR_TO_DATE(u.join_date, '%d-%m-%Y')) + 1 + DAY(CURDATE()) > 15 THEN 1 ELSE 0 END
BETWEEN a.starting_exp_months AND a.end_exp_months
Output (untuk data sampel Anda, termasuk semua pengguna karena mereka semua cocok dengan salah satu rentang pengalaman):
id name starting_exp_months end_exp_months
1 Sam 9 24
2 Moe 9 24
3 Tim 0 6
4 Sal 9 24
5 Joe 0 6
Saya telah membuat demo kecil di dbfiddle yang menunjukkan langkah-langkah untuk mencapai hasil.