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