SquadsActivityMonitor/sqlite2postgres.py

83 lines
2.7 KiB
Python

"""
Script to transfer data from sqlite DB to postgres DB
"""
import psycopg2.extensions
import psycopg2.extras
import sqlite3
from model import postgres_sql_requests
import time
import config
insert_pg = """insert into squads_stats_states (action_id, leaderboard_type, platform, squadron_id, score,
percentile, rank, name, tag, timestamp)
values
(%(action_id)s, %(leaderboard_type)s, %(platform)s, %(squadron_id)s, %(score)s,
%(percentile)s, %(rank)s, %(name)s, %(tag)s, %(timestamp)s);"""
sqlite_conn: sqlite3.Connection = sqlite3.connect('squads_stat.sqlite3', check_same_thread=False)
sqlite_conn.row_factory = lambda c, r: dict(zip([col[0] for col in c.description], r))
pg_conn: psycopg2.extensions.connection = psycopg2.connect(
user=config.postgres_username,
password=config.postgres_password,
host=config.postgres_hostname,
port=config.postgres_port,
database=config.postgres_database_name,
)
with pg_conn:
with pg_conn.cursor() as cursor:
cursor.execute(postgres_sql_requests.schema_create)
def initial_pull_sqlite_to_postgres() -> None:
"""
Function for initial transferring data from sqlite to postgres
:return:
"""
with pg_conn:
with pg_conn.cursor() as cursor:
start = time.time()
insert_statement = ''
sqlite_content = sqlite_conn.execute('select * from squads_stats_states;').fetchall()
# for row in sqlite_content:
# # cursor.execute(insert_pg, row)
# insert_statement += cursor.mogrify(insert_pg, row).decode('utf-8')
# print((time.time() - start) * 100, 'ms for creating insert_statement')
# print('inserting')
cursor.executemany(insert_pg, sqlite_content)
# 149619.26856040955 ms total
print((time.time() - start) * 100, 'ms total')
def continues_pull_sqlite_to_postgres() -> None:
"""
Function to synchronize data from sqlite to postgres table
:return:
"""
with pg_conn:
with pg_conn.cursor() as cursor:
cursor: psycopg2.extensions.cursor
cursor.execute('select action_id from squads_stats_states order by action_id desc limit 1;')
last_action_id_postgres: int = cursor.fetchone()[0]
new_records = sqlite_conn.execute('select * from squads_stats_states where action_id > :action_id;',
{'action_id': last_action_id_postgres}).fetchall()
cursor.executemany(insert_pg, new_records)
continues_pull_sqlite_to_postgres()
pg_conn.close()
sqlite_conn.close()