Python 작업 MySQL 상세 설명 및 인 스 턴 스

4463 단어 PythonMySQL
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 발행 버 전에 서 선택 할 수 있 는 설치 구성 요소 입 니 다.
읽 어 주 셔 서 감사합니다. 여러분 에 게 도움 이 되 기 를 바 랍 니 다.본 사이트 에 대한 여러분 의 지지 에 감 사 드 립 니 다!

좋은 웹페이지 즐겨찾기