notebookVB

This commit is contained in:
2026-01-03 11:19:23 +01:00
parent 5adefe0433
commit bef50acc9b
2 changed files with 103 additions and 24 deletions

View File

@@ -1,37 +1,114 @@
import pymysql import pymysql
from knihovny.medicus_db import MedicusDB from knihovny.medicus_db import MedicusDB
# ========================================== # ==========================================
# CONFIGURATION # CONFIGURATION
# ========================================== # ==========================================
HOST = "192.168.1.4" MEDICUS_HOST = "192.168.1.4"
DB_PATH = r"z:\Medicus 3\data\MEDICUS.FDB" MEDICUS_DB_PATH = r"z:\Medicus 3\data\MEDICUS.FDB"
# ========================================== MYSQL_CONFIG = {
# MYSQL CONNECTION "host": "192.168.1.76",
# ========================================== "port": 3307,
mysql = pymysql.connect( "user": "root",
host="192.168.1.76", "password": "Vlado9674+",
port=3307, "database": "medevio",
user="root", "charset": "utf8mb4",
password="Vlado9674+", "autocommit": True
database="medevio", }
charset="utf8mb4",
autocommit=True
)
# ========================================== # ==========================================
# INIT CONNECTIONS # INIT CONNECTIONS
# ========================================== # ==========================================
db = MedicusDB(HOST, DB_PATH) print("Connecting to Medicus...")
medicus = MedicusDB(MEDICUS_HOST, MEDICUS_DB_PATH)
print("Connecting to MySQL...")
mysql = pymysql.connect(
cursorclass=pymysql.cursors.DictCursor,
**MYSQL_CONFIG
)
# ========================================== # ==========================================
# FETCH REGISTERED PATIENTS # FETCH REGISTERED PATIENTS (MEDICUS)
# ========================================== # ==========================================
patients = db.get_active_registered_patients() print("Fetching registered patients from Medicus...")
patients = medicus.get_active_registered_patients(as_dict=True)
sqlcon= patients_by_rc = {
select * from (select *, ROW_NUMBER() over (partition by rc order by k_datu desc) as rn from vzp_stav_pojisteni) t p["rodcis"]: p
where t.rn=1 and t.stav<>"1"; for p in patients
}
print(f"Loaded {len(patients_by_rc)} registered patients")
# ==========================================
# FETCH LAST INSURANCE STATES (MYSQL)
# ==========================================
print("Fetching last insurance states from MySQL...")
sql_last_states = """
SELECT
rc,
stav
FROM (
SELECT
rc,
stav,
ROW_NUMBER() OVER (
PARTITION BY rc
ORDER BY k_datu DESC
) AS rn
FROM vzp_stav_pojisteni
) t
WHERE t.rn = 1
"""
with mysql.cursor() as cur:
cur.execute(sql_last_states)
last_states = cur.fetchall()
print(f"Loaded {len(last_states)} last insurance states")
# ==========================================
# COMPARE & FIND NON-OK STATES
# ==========================================
suspected = []
for row in last_states:
rc = row["rc"]
stav = row["stav"]
if rc in patients_by_rc and stav != "1":
p = patients_by_rc[rc]
suspected.append({
"rc": rc,
"prijmeni": p["prijmeni"],
"jmeno": p["jmeno"],
"poj": p["poj"],
"stav": stav
})
# ==========================================
# OUTPUT
# ==========================================
print("\n==========================================")
print("PACIENTI S NEOK STAVEM POJIŠTĚNÍ")
print("==========================================")
if not suspected:
print("✔️ Všichni registrovaní pacienti mají stav 1")
else:
for s in suspected:
print(
f'{s["rc"]} | {s["prijmeni"]} {s["jmeno"]} '
f'| pojišťovna={s["poj"]} | stav={s["stav"]}'
)
print("\nCelkem nalezeno:", len(suspected))
# ==========================================
# CLEANUP
# ==========================================
medicus.close()
mysql.close()

View File

@@ -22,7 +22,7 @@ class MedicusDB:
cols = [d[0].strip().lower() for d in self.cur.description] cols = [d[0].strip().lower() for d in self.cur.description]
return [dict(zip(cols, row)) for row in self.cur.fetchall()] return [dict(zip(cols, row)) for row in self.cur.fetchall()]
def get_active_registered_patients(self): def get_active_registered_patients(self, as_dict=False):
sql = """ sql = """
SELECT SELECT
kar.rodcis, kar.rodcis,
@@ -36,7 +36,9 @@ class MedicusDB:
AND kar.rodcis IS NOT NULL AND kar.rodcis IS NOT NULL
AND kar.rodcis <> '' AND kar.rodcis <> ''
""" """
return self.query(sql) # or self.query_dict(sql) if as_dict:
return self.query_dict(sql)
return self.query(sql)
def close(self): def close(self):
self.conn.close() self.conn.close()