목차
Python의 반복 MySQL 쿼리에서 영구 데이터 검색
문제
해결책
설명
데이터 베이스 MySQL 튜토리얼 Python에서 반복되는 MySQL 쿼리가 동일한 결과를 반환하는 이유는 무엇입니까?

Python에서 반복되는 MySQL 쿼리가 동일한 결과를 반환하는 이유는 무엇입니까?

Nov 08, 2024 pm 09:10 PM

Why Do Repeated MySQL Queries in Python Return Identical Results?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

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

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

Docker에서 MySQL 메모리 사용을 줄입니다 Docker에서 MySQL 메모리 사용을 줄입니다 Mar 04, 2025 pm 03:52 PM

Docker에서 MySQL 메모리 사용을 줄입니다

Alter Table 문을 사용하여 MySQL에서 테이블을 어떻게 변경합니까? Alter Table 문을 사용하여 MySQL에서 테이블을 어떻게 변경합니까? Mar 19, 2025 pm 03:51 PM

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

MySQL의 문제를 해결하는 방법 공유 라이브러리를 열 수 없습니다. MySQL의 문제를 해결하는 방법 공유 라이브러리를 열 수 없습니다. Mar 04, 2025 pm 04:01 PM

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

Linux에서 MySQL을 실행합니다 (Phpmyadmin이있는 Podman 컨테이너가 포함되지 않음) Linux에서 MySQL을 실행합니다 (Phpmyadmin이있는 Podman 컨테이너가 포함되지 않음) Mar 04, 2025 pm 03:54 PM

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

sqlite 란 무엇입니까? 포괄적 인 개요 sqlite 란 무엇입니까? 포괄적 인 개요 Mar 04, 2025 pm 03:55 PM

sqlite 란 무엇입니까? 포괄적 인 개요

MacOS에서 여러 MySQL 버전을 실행 : 단계별 가이드 MacOS에서 여러 MySQL 버전을 실행 : 단계별 가이드 Mar 04, 2025 pm 03:49 PM

MacOS에서 여러 MySQL 버전을 실행 : 단계별 가이드

MySQL 연결에 대한 SSL/TLS 암호화를 어떻게 구성합니까? MySQL 연결에 대한 SSL/TLS 암호화를 어떻게 구성합니까? Mar 18, 2025 pm 12:01 PM

MySQL 연결에 대한 SSL/TLS 암호화를 어떻게 구성합니까?

인기있는 MySQL GUI 도구는 무엇입니까 (예 : MySQL Workbench, Phpmyadmin)? 인기있는 MySQL GUI 도구는 무엇입니까 (예 : MySQL Workbench, Phpmyadmin)? Mar 21, 2025 pm 06:28 PM

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

See all articles