Heim > Datenbank > MySQL-Tutorial > Warum geben meine wiederholten MySQL-Abfragen nicht die neuesten Daten zurück?

Warum geben meine wiederholten MySQL-Abfragen nicht die neuesten Daten zurück?

Susan Sarandon
Freigeben: 2024-11-11 03:10:02
Original
1074 Leute haben es durchsucht

Why Are My Repeated MySQL Queries Not Returning the Latest Data?

Wiederholte MySQL-Abfragen geben nicht die neuesten Daten zurück: Beheben des Problems durch Transaktions-Commit

In Python, während wiederholt eine sich schnell ändernde MySQL-Datenbank abgefragt wird, Es ist wichtig sicherzustellen, dass jede Abfrage die aktuellsten Daten abruft. Bei einigen kann es jedoch zu dem Problem kommen, dass nachfolgende Abfragen trotz Änderungen in der Datenbank identische Daten zurückgeben. Dies liegt an der zugrunde liegenden Isolationsstufe der Datenbankverbindung.

Das Konzept der Isolationsstufen bestimmt, wie Transaktionen voneinander isoliert werden. Im Fall der Standardisolationsstufe von MySQL, REPEATABLE READ, basiert jede Abfrage innerhalb derselben Transaktion auf einem Snapshot der Datenbank, der zu Beginn der Transaktion erstellt wurde. Dies bedeutet, dass nachfolgende Abfragen keine Datenbankänderungen widerspiegeln, die während der aktiven Transaktion vorgenommen wurden.

Um dieses Problem zu beheben, ist es wichtig, die Verbindung nach jeder Abfrage festzuschreiben. Dadurch wird eine neue Transaktion initiiert und sichergestellt, dass die nächste Abfrage mit dem neuesten Datenbank-Snapshot ausgeführt wird. Hier ist ein Beispiel:

<code class="python">while True:
    # SQL query
    sql = "SELECT * FROM table"

    # Read the database, store as a dictionary
    mycursor = mydb.cursor(dictionary=True)
    mycursor.execute(sql)

    # Store data in rows
    myresult = mycursor.fetchall()

    # Transfer data into list
    for row in myresult:
        myList[int(row["rowID"])] = (row["a"], row["b"], row["c"])

        print(myList[int(row["rowID"])])

    # Commit !
    mydb.commit()
    print("---")
    sleep (0.1)</code>
Nach dem Login kopieren

Durch das Commit nach jeder Abfrage stellte die Verbindung eine neue Transaktion her und stellte sicher, dass jede nachfolgende Abfrage den neuesten Datenbank-Snapshot liest und so die neuesten Datenbankänderungen widerspiegelt. Dies löst das Problem wiederholter Abfragen, die ständig veraltete Daten zurückgeben.

Das obige ist der detaillierte Inhalt vonWarum geben meine wiederholten MySQL-Abfragen nicht die neuesten Daten zurück?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage