파이썬에서 pymysql을 이용하여 MySQL의 테이블 생성 및 삭제하는 방법을 소개합니다.
MySQL의 다른 글들도 참고해주세요.
1. pymysql 설치
pymysql는 파이썬의 MySQL 라이브러리입니다. pip 명령어로 설치할 수 있습니다.
$ python3 -m pip install PyMySQL2. 테이블 생성
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)