파이썬에서 pymysql을 이용하여 MySQL의 DB 생성 및 삭제하는 방법을 소개합니다.
MySQL의 다른 글들도 참고해주세요.
1. pymysql 설치
pymysql는 파이썬의 MySQL 라이브러리입니다. pip 명령어로 설치할 수 있습니다.
$ python3 -m pip install PyMySQL
2. DB 생성
다음 코드는 DB를 생성하는 예제입니다.
MySQL 서버가 설치되어있고, 계정이 모두 생성된 상태에서 connect()
로 서버에 접속합니다.
cursor를 통해 SQL 구문을 실행하여 DB를 생성합니다. with
구문을 사용하기 때문에 cursor, conn의 close()
를 호출할 필요가 없습니다. with 구문 종료 시점에 자동으로 호출됩니다.
import pymysql
conn = pymysql.connect(host='localhost',
user='testuser',
password='password!@',
charset='utf8')
with conn:
with conn.cursor() as cur:
cur.execute('CREATE DATABASE testdb')
conn.commit()
MySQL 콘솔에서 다음과 같이 DB가 생성되었는지 확인할 수 있습니다.
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| mydb |
| mysql |
| performance_schema |
| sys |
| testdb |
+--------------------+
3. DB 생성 확인
다음과 같이 파이썬에서 생성된 DB들을 확인할 수 있습니다.
import pymysql
conn = pymysql.connect(host='localhost',
user='testuser',
password='Fktm068**',
db='testdb',
charset='utf8')
sql = 'SHOW DATABASES'
with conn:
with conn.cursor() as cur:
cur.execute(sql)
for data in cur:
print(data)
Output:
('information_schema',)
('mysql',)
('performance_schema',)
('sys',)
('testdb',)
4. DB 삭제
다음과 같이 DB를 삭제할 수 있습니다.
import pymysql
conn = pymysql.connect(host='localhost',
user='testuser',
password='password!@',
charset='utf8')
with conn:
with conn.cursor() as cur:
cur.execute('DROP DATABASE testdb')
conn.commit()
MySQL 콘솔에서 DB가 제거되었는지 확인할 수 있습니다.
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| mydb |
| mysql |
| performance_schema |
| sys |
+--------------------+
SHOW DATABASES
SQL으로도 DB가 제거된 것을 확인할 수 있습니다.
Loading script...
Related Posts
- Python 소수점 반올림, round() 예제
- Python - String isdigit(), 문자열이 숫자인지 확인
- Python 소수점 버림, 4가지 방법
- 파이썬 주석 처리, 단축키 소개
- Python - Text 파일 읽고 쓰는 방법 (read, write, append)
- Python - String Formatting의 다양한 방법 정리(%, Str formatting, f-stirng)
- Python - os.path.join(), 폴더와 파일명으로 Path 생성
- Python - 파일을 읽고 한 줄씩 리스트에 저장
- Python - 문자열에서 줄바꿈(\n) 제거, 3가지 방법
- Python - Switch Case 구현 방법 (Match Case)
- 우분투에 Python 3.10 설치하는 방법
- Python - 문자열에서 특정 문자 제거, 3가지 방법
- Python - 함수 정의 및 호출 방법
- Python - 딕셔너리 초기화, 4가지 방법
- Python - input() 함수로 데이터 입력 받기
- Python - Tuple 사용 방법
- Python - 딕셔너리 정리 및 예제
- Python - String startswith(), 어떤 문자열로 시작하는지 확인
- Python - 날짜에서 월 이름 가져오기(숫자 -> 영어 이름 변환)
- Python - 어떤 날짜가 몇 주차인지 확인
- Python - D-Day 계산, 몇일 남았는지 날짜 세기
- Python - 날짜가 무슨 요일인지 계산
- Python - 어떤 날짜가 주말인지, 평일인지 확인
- Python - XML 생성 및 파일 저장
- Python - 특정 월의 시작 날짜, 마지막 날짜 얻기
- Python - XML 파싱, 태그 또는 요소 별로 읽기
- Python 버전 확인 방법 (터미널, cmd 명령어)
- Python - Selenium에서 웹페이지의 제목 가져오는 방법
- Python - 디렉토리, 파일 사이즈 계산
- Python 버전 확인 방법 (스크립트 또는 Command line)
- Python - 함수에서 두개 이상의 값 리턴
- Python - CSV 파일 읽기, 쓰기
- Python - 코드 실행 시간 측정
- Python - 반복문으로 리스트 순회 방법 (+ Index 출력)
- Python - with로 파일 열고 닫기