python cursor游标重置位置scroll_MySQL的游标
python操作mysql
安裝
python操作mysql數據庫,主要就是通過pymysql模塊
pip install pymysql
操作流程
1)建立數據庫連接對象 conn
2)通過 conn 創建操作sql的 游標對象
3)編寫sql交給 cursor 執行
4)如果是查詢,通過 cursor對象 獲取結果
5)操作完畢,端口操作與連接
代碼步驟
注意
1.對記錄增刪改默認需要commit()
準備
import pymysql
一.建立連接
conn = pymysql.connect(user='root', passwd='root', database='t5')
二.獲取游標對象
#注:游標不設置參數,查詢的結果就是數據元組,數據沒有標識性
#設置pymysql.cursors.DictCursor,查詢的結果是字典,key是表的字段cursor = conn.cursor(pymysql.cursors.DictCursor)
三.增刪改查
創建表
sql1="create table zx(id int)"
cursor.execute(sql1)
增
#單條添加
sql2='insert into zx values(%s)'
cursor.execute(sql2,(1,))
cursor.execute(sql2,(2,))
cursor.execute(sql2,(3,))
conn.commit()
#多條添加
cursor.executemany(sql2, [(4,), (5,)])
conn.commit()
刪
sql3="delete from zx where id =%s"
cursor.execute(sql3,3)
conn.commit()
改
sql4='update zx set id=10 where id =2'
cursor.execute(sql4)
conn.commit()
查
sql5='select * from zx'
cursor.execute(sql5)
#fetchone() 偏移一條取出
r1=cursor.fetchone()
print(r1)
#fetchmany(n) 偏移n條取出
r2=cursor.fetchmany(1)
print(r2)
#fetchall() 偏移剩余全部
r3=cursor.fetchall()
print(r3)
結果
{'id': 1}
[{'id': 10}]
[{'id': 4}, {'id': 5}]
結束
#釋放端口與連接
cursor.close()
conn.close()
游標其他用法
# 操作游標
# cursor.scroll(0, 'absolute') # absolute絕對偏移,游標重置,從頭開始偏移
cursor.scroll(-2, 'relative') # relative相對偏移,游標在當前位置進行左右偏移
事務
#轉賬案例
try:
sql1 = 'update t2 set money=money-1 where name="tom"'
r1 = cursor.execute(sql1)
sql2 = 'update t2 set money=money+1 where name="ruakei"' # 轉入的人不存在
r2 = cursor.execute(sql2)
except:
print('轉賬執行異常')
conn.rollback()
else:
print('轉賬沒有異常')
if r1 == 1 and r2 == 1:
print('轉賬成功')
conn.commit()
else:
conn.rollback()
sql注入攻擊
不要自己拼接參數,交給pymysql占位填充!
sql = 'select * from user where name=%s and password=%s'
row = cursor.execute(sql, (usr, pwd))
if row:
print('登錄成功')
else:
print('登錄失敗')
總結
以上是生活随笔為你收集整理的python cursor游标重置位置scroll_MySQL的游标的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: python读取excel
- 下一篇: python自动测试n_接口自动化:Je