[파이썬] MySQL 데이터 업데이트와 수정

MySQL은 널리 사용되는 관계형 데이터베이스 관리 시스템입니다. 많은 웹 애플리케이션과 소프트웨어에서 데이터를 저장하고 관리하기 위해 MySQL을 사용합니다. 데이터베이스에서는 데이터를 추가, 조회, 수정 및 삭제할 수 있어야 합니다. 이 글에서는 Python을 사용하여 MySQL 데이터를 업데이트 및 수정하는 방법에 대해 알아보겠습니다.

1. MySQL 연결

Python에서 MySQL 데이터베이스에 연결하기 위해 mysql-connector-python 패키지를 사용할 수 있습니다. 먼저 이 패키지를 설치해야 합니다. 다음 명령을 사용하여 패키지를 설치합니다:

`bash pip install mysql-connector-python \`

다음 예제 코드는 Python에서 MySQL에 연결하는 방법을 보여줍니다:

import mysql.connector

# MySQL 연결 설정
conn = mysql.connector.connect(
  host="localhost",
  user="username",
  password="password",
  database="database_name"
)

# 커서 생성
cursor = conn.cursor()

# 데이터베이스 쿼리 수행

# 연결 해제
conn.close()

2. 데이터 수정

MySQL 데이터베이스에서 데이터를 수정하려면 UPDATE 쿼리를 사용해야 합니다. 다음 예제 코드는 users 테이블에서 특정 사용자의 이름을 업데이트하는 방법을 보여줍니다:

import mysql.connector

# MySQL 연결 설정

user_id = 1
new_name = "John Doe"

# 데이터 업데이트 쿼리
update_query = "UPDATE users SET name = %s WHERE id = %s"
values = (new_name, user_id)

# 커서 생성

cursor.execute(update_query, values)

# 커밋
conn.commit()

# 연결 해제
conn.close()

위 예제 코드에서 UPDATE 쿼리는 %s를 사용하여 값들을 대체합니다. execute 메서드는 UPDATE 쿼리와 값들을 인자로 받아 데이터베이스에 해당 쿼리를 실행합니다. commit 메서드는 변경 사항을 데이터베이스에 반영하는 역할을 합니다.

3. 데이터 업데이트 예외 처리

데이터베이스 연산 중에 오류가 발생하는 경우를 대비하여 예외 처리를 추가하는 것이 좋습니다. 다음 예제 코드는 try-except 구문을 사용하여 데이터 업데이트 도중 발생하는 오류를 처리하는 방법을 보여줍니다:

import mysql.connector

# MySQL 연결 설정

user_id = 1
new_name = "John Doe"

update_query = "UPDATE users SET name = %s WHERE id = %s"
values = (new_name, user_id)

try:
    cursor.execute(update_query, values)
    conn.commit()
    print("데이터 업데이트 성공!")
except mysql.connector.Error as err:
    print("데이터 업데이트 실패: {}".format(err))

# 연결 해제
conn.close()

위 코드에서 try 블록 안에서 execute 메서드를 실행하고 commit 메서드를 호출합니다. 오류가 발생하면 except 블록에서 해당 오류를 처리하고 적절한 에러 메시지를 출력합니다.

결론

Python을 사용하여 MySQL 데이터를 업데이트하고 수정하는 방법에 대해 알아보았습니다. mysql-connector-python 패키지를 사용하여 MySQL 데이터베이스에 연결하고 쿼리를 실행하는 방법을 배웠습니다. 또한 데이터 업데이트 작업 중에 예외 처리를 추가하는 것이 중요하다는 것을 알게 되었습니다. 이러한 기술을 익히면 웹 애플리케이션 등에서 데이터를 신속하게 업데이트하고 수정할 수 있습니다.

참고 자료:
mysql-connector-python 공식 문서