Python 작업 MySQL 상세 설명 및 인 스 턴 스
Python 을 사용 하여 MySQL 을 진행 하 는 라 이브 러 리 는 주로 세 개 입 니 다.Python-MySQL(더 익숙 한 이름 은 MySQLdb 일 수 있 습 니 다),PyMySQL 과 SQLAlchemy 입 니 다.
Python-MySQL 은 자격 이 가장 많 고 핵심 은 C 언어 로 만 들 어 졌 으 며 인터페이스 가 세련 되 고 성능 이 가장 좋 으 며 환경 의존 도가 많 고 설치 가 복잡 하 다 는 단점 이 있 습 니 다.최근 2 년 동안 업 데 이 트 를 중단 하고 Python 2 만 지원 하 며 Python 3 은 지원 하지 않 습 니 다.
PyMySQL 은 Python-MySQL 을 대체 하기 위해 생 겨 났 으 며,순수 python 으로 만 들 어 졌 으 며,인 터 페 이 스 는 Python-MySQL 과 호 환 되 어 설치 가 편리 하고 Python 3 를 지원 합 니 다.
SQLAlchemy 는 ORM 프레임 워 크 로 바 텀 데이터 베 이 스 를 제공 하지 않 고 MySQLdb,PyMySQL 등 제3자 라 이브 러 리 를 통 해 이 루어 져 야 합 니 다.현재 SQLAlchemy 는 웹 프로 그래 밍 분야 에서 광범 위 하 게 응용 되 고 있 습 니 다.
본 고 는 주로 PyMySQL 의 정확 한 사용 방법 을 소개 하 는데 예시 코드 는 모두 실전 프로젝트 에서 선택 한 것 이다.
설치 하 다.
간단 한 방법:
pip install pymysql
인터넷 이 연결 되 지 않 으 면 오프라인 설치 가 필요 합 니 다.예 를 들 어:
pip install pymysql-x.x.x.tar.gz
가 져 오기
import pymysql
잇닿다
def connect_wxremit_db():
return pymysql.connect(host='10.123.5.28',
port=3306,
user='root',
password='root1234',
database='db_name',
charset='latin1')
조회 하 다.
def query_country_name(cc2):
sql_str = ("SELECT Fcountry_name_zh"
+ " FROM t_country_code"
+ " WHERE Fcountry_2code='%s'" % (cc2))
logging.info(sql_str)
con = mysql_api.connect_wxremit_db()
cur = con.cursor()
cur.execute(sql_str)
rows = cur.fetchall()
cur.close()
con.close()
assert len(rows) == 1, 'Fatal error: country_code does not exists!'
return rows[0][0]
단순 삽입
def insert_file_rec(self, file_name, file_md5):
con = mysql_api.connect_wxremit_db()
cur = con.cursor()
try:
sql_str = ("INSERT INTO t_forward_file (Ffile_name, Ffile_md5)",
+ " VALUES ('%s', '%s')" % (file_name, file_md5))
cur.execute(sql_str)
con.commit()
except:
con.rollback()
logging.exception('Insert operation error')
raise
finally:
cur.close()
con.close()
일괄 삽입
remit_ids = [('1234', 'CAD'), ('5678', 'HKD')]
con = mysql_api.connect_wxremit_db()
cur = con.cursor()
try:
cur.executemany("INSERT INTO t_order (Fremit_id, Fcur_type, Fcreate_time"
+ " VALUES (%s, %s, now())", new_items)
assert cur.rowcount == len(remit_ids), 'my error message'
con.commit()
except Exception as e:
con.rollback()
logging.exception('Insert operation error')
finally:
cur.close()
con.close()
업데이트
def update_refund_trans(self, remit_id):
con = mysql_api.connect_wxremit_db()
cur = con.cursor()
try:
sql_str = ("SELECT Fremit_id"
+ " FROM t_wxrefund_trans"
+ " WHERE Fremit_id='%s'" % remit_id
+ " FOR UPDATE")
logging.info(sql_str)
cur.execute(sql_str)
assert cur.rowcount == 1, 'Fatal error: The wx-refund record be deleted!'
sql_str = ("UPDATE t_wxrefund_trans"
+ " SET Fcheck_amount_flag=1"
+ ", Fmodify_time=now()"
+ " WHERE Fremit_id='%s'" % remit_id
logging.info(sql_str)
cur.execute(sql_str)
assert cur.rowcount == 1, 'The number of affected rows not equal to 1'
con.commit()
except:
con.rollback()
logging.exception('Update operation error')
raise
finally:
cur.close()
con.close()
PyMySQL 은 Python-MySQL 과 마찬가지 로 많은 Linux 발행 버 전에 서 선택 할 수 있 는 설치 구성 요소 입 니 다.읽 어 주 셔 서 감사합니다. 여러분 에 게 도움 이 되 기 를 바 랍 니 다.본 사이트 에 대한 여러분 의 지지 에 감 사 드 립 니 다!
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Python의 None과 NULL의 차이점 상세 정보그래서 대상 = 속성 + 방법 (사실 방법도 하나의 속성, 데이터 속성과 구별되는 호출 가능한 속성 같은 속성과 방법을 가진 대상을 클래스, 즉 Classl로 분류할 수 있다.클래스는 하나의 청사진과 같아서 하나의 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.