> 데이터 베이스 > MySQL 튜토리얼 > Python MySQL INSERT 문이 실패하는 이유는 무엇이며 어떻게 해결할 수 있습니까?

Python MySQL INSERT 문이 실패하는 이유는 무엇이며 어떻게 해결할 수 있습니까?

Mary-Kate Olsen
풀어 주다: 2024-12-09 14:57:12
원래의
600명이 탐색했습니다.

Why Does My Python MySQL INSERT Statement Fail, and How Can I Fix It?

MySQL 데이터베이스에 데이터 삽입

문제 설명

Python 스크립트를 사용하여 MySQL 데이터베이스에 값 188과 90을 삽입하려고 하면, 코드가 성공적으로 실행되지 않습니다. 다음 코드 조각은 실패한 시도를 보여줍니다.

import MySQLdb
conn = MySQLdb.connect(host= "localhost",
                  user="root",
                  passwd="newpassword",
                  db="engy1")
x = conn.cursor()
x.execute("SELECT *  FROM anooog1")
x.execute (" INSERT INTO anooog1 VALUES ('%s','%s') ", (188,90))
row = x.fetchall()
로그인 후 복사

해결 방법

삽입에 사용된 SQL 쿼리의 오류로 인해 문제가 발생합니다. MySQL 테이블에 데이터를 삽입하는 올바른 구문은 다음과 같습니다.

INSERT INTO table_name (column1, column2, ...) VALUES (value1, value2, ...)
로그인 후 복사

제공된 코드에서 값 앞뒤의 작은따옴표('')가 올바르지 않습니다. 이를 제거하면 쿼리가 성공적으로 실행될 수 있습니다.

또한 예기치 않은 오류로 인해 데이터베이스 변경 사항이 롤백되는 것을 방지하기 위해 예외 처리 메커니즘이 추가되었습니다. 아래 수정된 코드는 올바른 구현을 보여줍니다.

import MySQLdb
conn = MySQLdb.connect(host= "localhost",
                  user="root",
                  passwd="newpassword",
                  db="engy1")
x = conn.cursor()

try:
   x.execute("""INSERT INTO anooog1 VALUES (%s,%s)""",(188,90))
   conn.commit()
except:
   conn.rollback()

conn.close()
로그인 후 복사

이 수정된 코드는 지정된 MySQL 테이블에 값 188과 90을 성공적으로 삽입해야 합니다.

위 내용은 Python MySQL INSERT 문이 실패하는 이유는 무엇이며 어떻게 해결할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿