파이썬에서 pymysql을 이용하여 MySQL의 테이블 생성 및 삭제하는 방법을 소개합니다.
MySQL의 다른 글들도 참고해주세요.
1. pymysql 설치
pymysql는 파이썬의 MySQL 라이브러리입니다. pip 명령어로 설치할 수 있습니다.
$ python3 -m pip install PyMySQL
2. 테이블 생성
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 = '''CREATE TABLE user (
id int(11) NOT NULL AUTO_INCREMENT PRIMARY KEY,
name varchar(255),
email varchar(255)
)
'''
with conn:
with conn.cursor() as cur:
cur.execute(sql)
conn.commit()
MySQL 콘솔에서 다음과 같이 테이블이 생성되었는지 확인할 수 있습니다.
mysql> show tables from testdb;
+------------------+
| Tables_in_testdb |
+------------------+
| user |
+------------------+
다음 명령어로 테이블의 columns들도 확인할 수 있습니다.
mysql> show columns from user from testdb;
+-------+--------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-------+--------------+------+-----+---------+----------------+
| id | int | NO | PRI | NULL | auto_increment |
| name | varchar(255) | YES | | NULL | |
| email | varchar(255) | YES | | NULL | |
+-------+--------------+------+-----+---------+----------------+
3. 테이블 생성 확인
다음과 같이 파이썬에서 SQL을 실행하여 생성된 테이블을 확인할 수 있습니다.
import pymysql
conn = pymysql.connect(host='localhost',
user='testuser',
password='Fktm068**',
db='testdb',
charset='utf8')
sql = 'SHOW TABLES'
with conn:
with conn.cursor() as cur:
cur.execute(sql)
for data in cur:
print(data)
Output:
('user',)
4. 테이블 삭제
다음과 같이 테이블을 삭제할 수 있습니다. SQL 구문에서 IF EXISTS
는 테이블이 존재하는 경우만 삭제를 시도한다는 의미입니다.
SQL에서 IF EXISTS
를 제거하면 SQL이 수행될 때 테이블 삭제를 시도하며, 존재하지 않을 때는 에러가 발생합니다.
import pymysql
conn = pymysql.connect(host='localhost',
user='testuser',
password='Fktm068**',
db='testdb',
charset='utf8')
sql = "DROP TABLE IF EXISTS user"
with conn:
with conn.cursor() as cur:
cur.execute(sql)
conn.commit()
Loading script...
Related Posts
- Python - Yaml 파일 파싱하는 방법
- Python - 파일 내용 삭제
- Python - for문에서 리스트 순회 중 요소 값 제거
- Python - 두 리스트에서 공통 요소 값 찾기
- Python - 문자열 앞(뒤)에 0으로 채우기
- Python - 공백으로 문자열 분리
- Python - 중첩 리스트 평탄화(1차원 리스트 변환)
- Python - 16진수 문자열을 Int로 변환
- Python - 두 날짜, 시간 비교
- Python f-string으로 변수 이름, 값 쉽게 출력 (변수명 = )
- Python - nonlocal과 global 사용 방법
- Python 바다코끼리 연산자 := 알아보기
- Python - pip와 requirements.txt로 패키지 관리
- Python - 딕셔너리 보기 좋게 출력 (pprint)
- Python - Requests 사용 방법 (GET/POST/PUT/PATCH/DELETE)
- Python - 온라인 컴파일러 사이트 추천
- Python - os.walk()를 사용하여 디렉토리, 파일 탐색
- Python - 문자열 비교 방법
- Python - Text 파일 읽고 쓰는 방법 (read, write, append)
- Python - 리스트에서 첫번째, 마지막 요소 가져오는 방법
- Python - 두개의 리스트 하나로 합치기
- Python - 리스트의 마지막 요소 제거
- Python - 리스트의 첫번째 요소 제거
- Python 소수점 버림, 4가지 방법
- Python 코드 안에서 버전 확인 방법
- Python 소수점 반올림, round() 예제
- Python - 리스트 평균 구하기, 3가지 방법
- Python - bytes를 String으로 변환하는 방법
- Python - String을 bytes로 변환하는 방법
- Python 버전 확인 방법 (터미널, cmd 명령어)
- Python - 람다(Lambda) 함수 사용 방법
- Python - dict 정렬 (Key, Value로 sorting)
- Python - range() 사용 방법 및 예제
- Python - 리스트를 문자열로 변환
- Python - 문자를 숫자로 변환 (String to Integer, Float)