[python][자료구조] Python - MySQL 데이터 추가, 삭제, 업데이트

파이썬에서 pymysql을 이용하여 MySQL에 데이터를 추가(INSERT), 업데이트(UPDATE), 삭제(DELETE)하는 방법을 소개합니다.

MySQL의 다른 글들도 참고해주세요.

1. pymysql 설치

pymysql는 파이썬의 MySQL 라이브러리입니다. pip 명령어로 설치할 수 있습니다.

$ python3 -m pip install PyMySQL

2. 데이터 추가(INSERT)

다음 코드는 데이터를 추가하는 예제입니다.

MySQL 서버가 설치되어있고, 계정이 모두 생성된 상태에서 connect()로 서버에 접속합니다. cursor를 통해 SQL을 실행하여 데이터를 추가합니다. with 구문을 사용하기 때문에 cursor, conn의 close()를 호출할 필요가 없습니다. with 구문 종료 시점에 자동으로 호출됩니다.

import pymysql

conn = pymysql.connect(host='localhost',
                       user='testuser',
                       password='Fktm068**',
                       db='testdb',
                       charset='utf8')

sql = "INSERT INTO user (name, email) VALUES (%s, %s)"

with conn:
    with conn.cursor() as cur:
        cur.execute(sql, ('Jaehee', 'jaehee@example.com'))
        cur.execute(sql, ('Jeongeun', 'jeongeun@example.com'))
        conn.commit()

MySQL 콘솔에서 다음과 같이 데이터가 추가되었는지 확인할 수 있습니다.

mysql> select * from testdb.user;
+----+----------+----------------------+
| id | name     | email                |
+----+----------+----------------------+
|  1 | Jaehee   | jaehee@example.com   |
|  2 | Jeongeun | jeongeun@example.com |
+----+----------+----------------------+

3. 데이터 추가 확인

다음과 같이 파이썬에서 SELECT SQL을 실행하여 추가된 데이터를 확인할 수 있습니다. 하기 SQL은 user table에 있는 모든 데이터를 name으로 정렬하여 가져옵니다.

import pymysql

conn = pymysql.connect(host='localhost',
                       user='testuser',
                       password='Fktm068**',
                       db='testdb',
                       charset='utf8')

sql = "SELECT * FROM user ORDER BY name"

with conn:
    with conn.cursor() as cur:
        cur.execute(sql)
        result = cur.fetchall()
        for data in result:
            print(data)

Output:

경축! 아무것도 안하여 에스천사게임즈가 새로운 모습으로 재오픈 하였습니다.
어린이용이며, 설치가 필요없는 브라우저 게임입니다.
https://s1004games.com

(1, 'Jaehee', 'jaehee@example.com')
(2, 'Jeongeun', 'jeongeun@example.com')

4. 데이터 업데이트(UPDATE)

다음과 같이 기존에 추가된 항목들의 데이터를 업데이트할 수 있습니다. WHERE를 이용하여 변경하려는 데이터에 대한 조건을 설정합니다. email이 jahee@example.com인 데이터를 찾고, email을 jahee@test.com으로 변경합니다.

import pymysql

conn = pymysql.connect(host='localhost',
                       user='testuser',
                       password='Fktm068**',
                       db='testdb',
                       charset='utf8')

sql = "UPDATE user SET email = %s WHERE email = %s"

with conn:
    with conn.cursor() as cur:
        cur.execute(sql, ('jaehee@test.com', 'jaehee@example.com'))
        conn.commit()

MySQL 콘솔에서 다음과 같이 데이터가 업데이트되었는지 확인할 수 있습니다.

mysql> select * from testdb.user;
+----+----------+----------------------+
| id | name     | email                |
+----+----------+----------------------+
|  1 | Jaehee   | jaehee@test.com      |
|  2 | Jeongeun | jeongeun@example.com |
+----+----------+----------------------+

SELECT SQL으로 데이터가 업데이트되었는지 확인할 수도 있습니다.

5. 데이터 삭제(DELETE)

다음과 같은 SQL로 데이터를 삭제할 수 있습니다. WHERE를 이용하여 조건에 맞는 데이터만 삭제할 수 있습니다. cur.rowcount는 삭제된 항목들의 개수입니다.

import pymysql

conn = pymysql.connect(host='localhost',
                       user='testuser',
                       password='Fktm068**',
                       db='testdb',
                       charset='utf8')

sql = "DELETE FROM user WHERE name = %s"

with conn:
    with conn.cursor() as cur:
        cur.execute(sql, ('Jaehee'))
        conn.commit()
        print(cur.rowcount, "rows deleted")

Output:

1 rows deleted

MySQL 콘솔에서 다음과 같이 데이터가 삭제되었는지 확인할 수 있습니다.

mysql> select * from testdb.user;
+----+----------+----------------------+
| id | name     | email                |
+----+----------+----------------------+
|  2 | Jeongeun | jeongeun@example.com |
+----+----------+----------------------+
[출처] https://codechacha.com/ko/python-mysql-insert-update-delete/

 

 

본 웹사이트는 광고를 포함하고 있습니다.
광고 클릭에서 발생하는 수익금은 모두 웹사이트 서버의 유지 및 관리, 그리고 기술 콘텐츠 향상을 위해 쓰여집니다.
번호 제목 글쓴이 날짜 조회 수
491 [python, C++] Interfacing C++ and Python with the Python API : C++ 및 Python과 Python API의 인터페이스 file 졸리운_곰 2023.08.18 29
490 [python 일반] 파이참 에러 : Fatal Python error: init_stdio_encoding: failed to get the Python codec name of the stdio encoding file 졸리운_곰 2023.07.06 15
489 (Python) Jupyter Notebook 내에서만 환경 변수 설정 방법 졸리운_곰 2023.07.06 14
488 [python] 인공지능 python : 한글 문서 자동 요약 - lexrank 졸리운_곰 2023.07.06 15
487 [Python] 문자열에서 파일명 또는 폴더명으로 시스템상 지원되는 글자를 제외하고 삭제하기 졸리운_곰 2023.06.04 24
486 [python 일반] 파이썬 win32com 사용시 에러 해결 file 졸리운_곰 2023.06.04 119
485 [python 일반] win32com.gen_py 라이브러리의 오류 해결 졸리운_곰 2023.06.03 26
484 [Python 일반] 파일(폴더) 이름에 사용할 수 없는 특수 문자 제거 졸리운_곰 2023.06.03 24
483 [Python 일반] 파이썬에서 재귀적으로 깊은 계층적 디렉토리를 생성하기 위한 makedirs 졸리운_곰 2023.06.03 24
482 [python] 인공지능 katiehouse / django-scikit-learn-tutorial file 졸리운_곰 2023.06.03 34
» [python][자료구조] Python - MySQL 데이터 추가, 삭제, 업데이트 졸리운_곰 2023.05.13 27
480 [Python 인터넷] 네이버 뉴스 기사 크롤링 졸리운_곰 2023.05.13 35
479 [Django][Django restframework] Django REST framework 시작하기 file 졸리운_곰 2023.05.07 7
478 [Django] REST API 로그인 서버 만들기 (2) - DB 연동, 테스트 file 졸리운_곰 2023.05.07 14
477 [Django] REST API 로그인 서버 만들기 (1) - 코드 졸리운_곰 2023.05.07 21
476 [Django] user의 ip address 가지고 오기 졸리운_곰 2023.05.07 13
475 [Django] [Python_Django] You are trying to add a non-nullable field '필드명' to post without a default 해결 졸리운_곰 2023.05.07 19
474 [Django] [Python_Django] 관리자 계정에서 테이블 관리하기 file 졸리운_곰 2023.05.06 8
473 [python][자료구조] Python의 JSON - 문자열을 JSON으로 변환하는 방법 졸리운_곰 2023.05.06 25
472 [Django] TIP - 장고 데이터베이스 여러개 사용하기 (Django multidatabase) file 졸리운_곰 2023.05.05 11
대표 김성준 주소 : 경기 용인 분당수지 U타워 등록번호 : 142-07-27414
통신판매업 신고 : 제2012-용인수지-0185호 출판업 신고 : 수지구청 제 123호 개인정보보호최고책임자 : 김성준 sjkim70@stechstar.com
대표전화 : 010-4589-2193 [fax] 02-6280-1294 COPYRIGHT(C) stechstar.com ALL RIGHTS RESERVED