Python에서 반복되는 MySQL 쿼리가 동일한 결과를 반환하는 이유는 무엇입니까?
Python의 반복 MySQL 쿼리에서 영구 데이터 검색
Python 스크립팅에서는 동적 데이터를 캡처하기 위해 MySQL 데이터베이스를 자주 쿼리하는 것이 중요합니다. 이러한 데이터를 검색하기 위해 루프를 사용하는 경우 후속 가져오기에서 동일한 결과가 반환되는 것을 발견하면 혼란스러울 수 있습니다.
문제
지정된 Python 스크립트에서 루프는 MySQL을 반복적으로 실행하는 데 사용됩니다. 쿼리하고 결과를 목록에 저장합니다.
<code class="python">for i in range(listSize): # ... # SQL query sql = "SELECT * FROM table" # ...</code>
루프가 각 반복마다 데이터베이스에서 검색된 데이터를 새로 고칠 것이라는 예상에도 불구하고 스크립트는 동일한 결과를 반복적으로 검색합니다.
해결책
문제의 핵심은 MySQL의 트랜잭션 격리 수준에 있습니다. 기본적으로 MySQL에서 사용하는 스토리지 엔진인 InnoDB는 READ COMMITTED 격리 수준에서 작동하여 다음을 보장합니다.
"동일한 트랜잭션 내에서 일관된 읽기는 첫 번째 읽기에 의해 설정된 스냅샷을 읽습니다."
이는 트랜잭션 내의 후속 쿼리가 트랜잭션이 시작되었을 때 존재했던 데이터를 검색한다는 의미입니다. 이 문제를 해결하려면 루프의 각 반복이 mydb.commit() 명령으로 끝나야 합니다.
<code class="python">import ... # ... while True: # ... # SQL query sql = "SELECT * FROM table" # ... mydb.commit()</code>
연결을 커밋함으로써 스크립트는 데이터베이스가 트랜잭션 중에 발생한 변경 사항을 강제로 캡처하도록 하여 후속 작업이 쿼리는 데이터베이스의 현재 상태를 반영합니다.
설명
MySQL 연결 내의 각 루프 반복은 기본적으로 일관된 스냅샷에서 읽는 별도의 트랜잭션으로 처리됩니다. 각 반복이 끝날 때 연결을 커밋하면 후속 트랜잭션이 가장 최근 스냅샷을 읽고 이전 트랜잭션의 변경 사항을 반영합니다.
위 내용은 Python에서 반복되는 MySQL 쿼리가 동일한 결과를 반환하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











Alter Table 문을 사용하여 MySQL에서 테이블을 어떻게 변경합니까?

MySQL의 문제를 해결하는 방법 공유 라이브러리를 열 수 없습니다.

Linux에서 MySQL을 실행합니다 (Phpmyadmin이있는 Podman 컨테이너가 포함되지 않음)

인기있는 MySQL GUI 도구는 무엇입니까 (예 : MySQL Workbench, Phpmyadmin)?
