Das Wort rank
ist ein reserviertes Wort in MySQL 8.
Verwenden Sie also einen anderen Aliasnamen oder markieren Sie den Aliasnamen mit einem Backtick.
Und in MySql 8 können Sie Fensterfunktionen
SELECT
mapname,
DENSE_RANK() OVER (PARTITION BY mapname, zonegroup, steamid, style ORDER BY runtime DESC) AS `rank`,
COUNT(*) OVER (PARTITION BY mapname, zonegroup, steamid, style) AS total
FROM ck_bonus
WHERE steamid = '%s' AND style = %i;