5、第八周 - 網路編程進階 - Python 串連 Mysql

來源:互聯網
上載者:User

標籤:ctc   基本結構   關於   row_count   擷取   com   輸出   mys   connect   

 

Python操作MySQL主要使用兩種方式:
原生模組:pymsql 其中pymsql是Python中操作MySQL的模組,其使用方法和MySQLdb幾乎相同。
ORM架構:SQLAchemy

 

Mysql pymysql 基本步驟

1、pymysql 基本結構文法如下:

import pymysql#建立串連conn = pymysql.connect(host=‘10.10.28.5‘,port=3306,user=‘chen‘,passwd=‘Chen1203..‘,db=‘school‘,charset="utf8")#建立遊標cursor = conn.cursor() #建立當前資料的遊標#執行SQL,並返回影響行數,常規的資料庫操作命令:select、update、insert#cursor.execute("insert into a (number) VALUES (1203)")#執行SQL,並返回影響行數,執行多次cursor.executemany("insert into a (number) VALUES (%s)",[("1000"),("1001"),("1002")])cursor.execute("select * from a  ")#output = cursor.fetchmany(3) #根據執行SQL的返回,讀取前面三個數字#output = cursor.fetchone()   #根據執行SQL的返回,讀取一個數字output = cursor.fetchall()    #根據執行SQL的返回,進行全部列印print(output)#提交,不然無法儲存建立或者修改資料conn.commit()#關閉遊標cursor.close()#關閉串連conn.close()輸出:( (1203,), (1203,), (1203,), (1203,), (1000,), (1001,), (1002,))

 註:存在中文的時候,串連需要添加charset=‘utf8‘,否則中文顯示亂碼。

2、擷取建立資料的自增ID號

import pymysql#建立串連conn = pymysql.connect(host=‘103.66.55.234‘,port=3306,user=‘chen‘,passwd=‘Chen1203..‘,db=‘school‘,charset="utf8")#建立遊標cursor = conn.cursor() #建立當前資料的遊標#執行SQL,並返回影響行數,常規的資料庫操作命令:select、update、insert#cursor.execute("insert into a (number) VALUES (1203)")#執行SQL,並返回影響行數,執行多次cursor.executemany("insert into chen (name) VALUES (%s)",[("qing4"),("qing5"),("qing6")])#提交,不然無法儲存建立或者修改資料conn.commit()#關閉遊標cursor.close()#關閉串連conn.close()new_id = cursor.lastrowid #擷取自增idprint (new_id)

 3、移動遊標

操作都是靠遊標,那對遊標的控制也是必要的

註:在fetch資料時按照順序進行,可以使用cursor.scroll(num,mode)來移動遊標位置,如:cursor.scroll(1,mode=‘relative‘) # 相對當前位置移動cursor.scroll(2,mode=‘absolute‘) # 相對絕對位置移動

 4、資料類型

關於預設擷取的資料是元祖類型,如果想要或者字典類型的資料

import pymysql#建立串連conn = pymysql.connect(host=‘103.66.53.98‘,port=3306,user=‘chen‘,passwd=‘Chen1203..‘,db=‘school‘,charset="utf8")#設定遊標為字典類型cursor = conn.cursor(cursor=pymysql.cursors.DictCursor) cursor.execute("select * from chen")row = cursor.fetchall()print(row)#提交conn.commit()#關閉遊標cursor.close()#關閉串連conn.close()

 5、調用預存程序

A、無參數預存程序

import pymysql conn = pymysql.connect(host=‘127.0.0.1‘, port=3306, user=‘root‘, passwd=‘‘, db=‘tkq1‘)#遊標設定為字典類型cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)#無參數預存程序cursor.callproc(‘p2‘)  #等價於cursor.execute("call p2()") row_1 = cursor.fetchone()print row_1 conn.commit()cursor.close()conn.close()

 B、有參數的預存程序

import pymysql conn = pymysql.connect(host=‘127.0.0.1‘, port=3306, user=‘root‘, passwd=‘‘, db=‘tkq1‘)cursor = conn.cursor(cursor=pymysql.cursors.DictCursor) cursor.callproc(‘p1‘, args=(1, 22, 3, 4))#擷取執行完儲存的參數,參數@開頭cursor.execute("select @p1,@_p1_1,@_p1_2,@_p1_3")  #{u‘@_p1_1‘: 22, u‘@p1‘: None, u‘@_p1_2‘: 103, u‘@_p1_3‘: 24}row_1 = cursor.fetchone()print row_1conn.commit()cursor.close()conn.close()

 6、使用with簡化串連過程

使用上下文管理,簡化串連過程

import pymysqlimport contextlib#定義上下文管理器,串連後自動關閉串連@contextlib.contextmanagerdef mysql(host=‘127.0.0.1‘, port=3306, user=‘root‘, passwd=‘‘, db=‘tkq1‘,charset=‘utf8‘):  conn = pymysql.connect(host=host, port=port, user=user, passwd=passwd, db=db, charset=charset)  cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)  try:    yield cursor  finally:    conn.commit()    cursor.close()    conn.close() # 執行sqlwith mysql() as cursor:  print(cursor)  row_count = cursor.execute("select * from tb7")  row_1 = cursor.fetchone()  print row_count, row_1

 pymysql防注入:參考連結 https://www.cnblogs.com/wt11/p/6141225.html

 

5、第八周 - 網路編程進階 - Python 串連 Mysql

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.