Действителната грешка е причинена от не използване на контейнери, както трябва .
Освен това наистина не искате да се свързвате отново с базата данни по този начин за всеки елемент. Освен това можете да се ангажирате само когато всичко е готово:
connection = mysql.connector.connect(
host="localhost", user="root", passwd="admin", database="python"
)
cursor = connection.cursor()
for child in root:
for element in child:
for subelement in element:
a = subelement.attrib["currency"]
b = subelement.text
result = cursor.execute(
"INSERT INTO valoare (moneda, flux) VALUES (%s, %s)", (a, b)
)
connection.commit()