From d89ce6f0fd294f4026773d5d1ba9095b111930ee Mon Sep 17 00:00:00 2001 From: jenz Date: Wed, 9 Aug 2023 22:35:07 +0200 Subject: [PATCH] added file for generating table with 5 best times from each map --- .../python3/generate_top_5_times_query.py | 55 +++++++++++++++++++ 1 file changed, 55 insertions(+) create mode 100644 RaceTimer/python3/generate_top_5_times_query.py diff --git a/RaceTimer/python3/generate_top_5_times_query.py b/RaceTimer/python3/generate_top_5_times_query.py new file mode 100644 index 00000000..4a9b3035 --- /dev/null +++ b/RaceTimer/python3/generate_top_5_times_query.py @@ -0,0 +1,55 @@ +from settings import get_connection_racetimer + +def main(): + with get_connection_racetimer() as conn: + with conn.cursor(buffered=True) as cur: + sql_statement = """ + select column_name from information_schema.columns + where table_schema = 'unloze_racetimer_css' + and TABLE_NAME = 'zetimer_table_new' + order by table_name,ordinal_position + """ + cur.execute(sql_statement) + res = cur.fetchall() + + #removing steamid and name + res.pop(0) + res.pop(0) + sql_statement = "TRUNCATE TABLE unloze_racetimer_css.top5" + cur.execute(sql_statement) + for index, result in enumerate(res): + result = result[0] + sql_statement = f"""alter table unloze_racetimer_css.top5 + add column if not exists {result} DOUBLE """ + cur.execute(sql_statement) + if index == 0: + sql_statement = f""" + insert into unloze_racetimer_css.top5 ({result}) + SELECT t2.{result} + FROM unloze_racetimer_css.zetimer_table_new t2 + WHERE + t2.{result} > 0 + ORDER BY t2.{result} ASC + LIMIT 5 + """ + else: + sql_statement = f""" + update unloze_racetimer_css.top5 t + INNER JOIN ( + SELECT + {result}, + ROW_NUMBER() OVER (ORDER BY {result} ASC) AS row_num + FROM unloze_racetimer_css.zetimer_table_new + WHERE {result} > 0 + limit 5 + ) t2 ON t.id = t2.row_num + set t.{result} = t2.{result} + where t.id = t2.row_num + """ + cur.execute(sql_statement) + conn.commit() + conn.close() + +if __name__ == '__main__': + main() +