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

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

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-12-09 14:57:12601검색

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

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