Zwykle obliczenie DOB jest dość łatwe w mysql, gdy chcesz obliczyć lata bez ułamka jako
mysql> select timestampdiff(YEAR,'1981-06-01',now());
+----------------------------------------+
| timestampdiff(YEAR,'1981-06-01',now()) |
+----------------------------------------+
| 33 |
+----------------------------------------+
Ale ponieważ potrzebujesz również ułamka, to powinno wystarczyć
mysql> select format(datediff(curdate(),'1981-06-01') / 365.25,2);
+-----------------------------------------------------+
| format(datediff(curdate(),'1981-06-01') / 365.25,2) |
+-----------------------------------------------------+
| 33.02 |
+-----------------------------------------------------+
Za rok uważa się 365,25 dni.
Więc w twoim przypadku możesz mieć zapytanie jako
select
format(datediff(curdate(),dob) / 365.25,2) as dob
from players limit 5;