標籤: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