亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

Python 操作MySQL詳解及實(shí)例

系統(tǒng) 1768 0

Python 操作MySQL詳解及實(shí)例

使用Python進(jìn)行MySQL的庫主要有三個(gè), Python-MySQL(更熟悉的名字可能是MySQLdb),PyMySQL和SQLAlchemy。

Python-MySQL資格最老,核心由C語言打造,接口精煉,性能最棒,缺點(diǎn)是環(huán)境依賴較多,安裝復(fù)雜,近兩年已停止更新,只支持Python2,不支持Python3。

PyMySQL為替代Python-MySQL而生,純python打造,接口與Python-MySQL兼容,安裝方便,支持Python3。

SQLAlchemy是一個(gè)ORM框架,它并不提供底層的數(shù)據(jù)庫操作,而是要借助于MySQLdb、PyMySQL等第三方庫來完成,目前SQLAlchemy在Web編程領(lǐng)域應(yīng)用廣泛。

本文主要介紹PyMySQL的正確使用方法,示例代碼都是選自實(shí)戰(zhàn)項(xiàng)目。

安裝

簡單的方式:

            
pip install pymysql
          

如果無法聯(lián)網(wǎng),需要進(jìn)行離線安裝,例如:

            
pip install pymysql-x.x.x.tar.gz
          

導(dǎo)入

            
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已經(jīng)相當(dāng)成熟,和Python-MySQL一樣,它在很多Linux發(fā)行版本中都是可選的安裝組件。

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長非常感激您!手機(jī)微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 国产做受视频激情播放 | 国产欧美在线观看精品一区二区 | 一级毛片区 | 九九久久精品国产 | 日本h片a毛片在线播放 | 亚洲欧美日韩精品中文乱码 | 福利视频网 | 国产精品久久久久久影视 | 欧美日本在线视频 | 精品一区二区乱码久久乱码 | 2021国产精品系列一区二区 | 免费激情片 | 奇米影视第四色在线观看 | 91在线视屏 | 色天使色婷婷丁香久久综合 | 国产片欧美片亚洲片久久综合 | 男人爱看的网站 | 婷婷激情综合网 | 九九爱精品视频 | 一区中文字幕 | 一级毛片短视频 | 欧美成人久久久免费播放 | 国产大片免费观看中文字幕 | 久久久99精品久久久 | 午夜毛片| 欧美成人三级一区二区在线观看 | 国产视频久久久 | 日韩一级视频免费观看 | 麻豆一区二区三区在线观看 | 中文精品久久久久国产网址 | 久久精品视频7 | 天天躁狠狠躁夜躁2021 | 一区二区中文字幕亚洲精品 | 成人黄色毛片 | 国产成+人+综合+亚洲专 | 99re6在线视频免费精品 | 久久久久久久国产a∨ | 中文字幕在线高清 | 乱子伦xxx欧美| 国产第一页久久亚洲欧美国产 | 欧美日本高清视频在线观看 |