python pymsql的用法 180903
阿新 • • 發佈:2018-09-03
無需 insert absolute 所有 內容 ict 條件 sql註入 使用
一.
1.pymysql 的下載
pip3 install pymysql
2.pymysql的使用
import pymysql
name=input("請輸入用戶名:")
password=input("請輸入密碼:")
# 1.連接
conn=pymysql.connect(
host="127.0.0.1",
port=3306,
db="db5",
user="root",
password="",
charset="utf8"
)
# 2.創建遊標
cur=conn.cursor()
# 註意 %s需要加引號
sql="select * from userinfo where name=‘%s‘ and password=‘%s‘"%(name,password)
result=cur.execute(sql)
# 執行sql語句返回sql查詢成功的記錄數目
print(result)
# 關閉遊標和連接
cur.close()
conn.close()
if result:
print("登陸成功")
else:
print("登陸失敗")
二,execute()之sql註入
# 問題 :
# 最後那一個空格,在一條sql語句中如果遇到select * from userinfo where username=‘mjj‘ -- asadasdas‘ and pwd=‘‘ 則--之後的條件被註釋掉了(註意--後面還有一個空格)
# 1.sql 註入之:用戶存在,繞過密碼;
# mjj‘ -- 任意字符
#2.sql註入之:用戶不存在,繞過用戶與密碼;
# xxx‘ or 1=1 -- 任意字符
# 解決方案:
# 錯誤原因:對sql進行字符串拼接
# 改寫為(execute幫我們做字符串拼接,我們無需且一定不能再為%s加引號了)
import pymysql
name=input("請輸入用戶名:")
password=input("請輸入密碼:")
# 1.連接
conn=pymysql.connect(
host="127.0.0.1",
port=3306,
db="db5",
user="root",
password="",
charset="utf8"
)
# 2.創建遊標
cur=conn.cursor()
#%s不加引號 pymysql 自動加
sql="select * from userinfo where name=%s and password=%s"
result=cur.execute(sql,[name,password])
# 執行sql語句返回sql查詢成功的記錄數目
print(result)
# 關閉遊標和連接
cur.close()
conn.close()
if result:
print("登陸成功")
else:
print("登陸失敗")
三 增刪改 conn.commit()
commit()方法:在數據庫裏增、刪、改的時候,必須要進行提交,否則插入的數據不生效。
import pymysql
name=input("請輸入用戶名:")
password=input("請輸入密碼:")
# 1.連接
conn=pymysql.connect(
host="127.0.0.1",
port=3306,
db="db5",
user="root",
password="",
charset="utf8"
)
# 2.創建遊標
cur=conn.cursor()
# 操作:
sql="insert into userinfo(name,password) values(%s,%s)"
# 插入一條數據:
result=cur.execute(sql,[name,password]) # 執行sql語句返回sql查詢成功的記錄數目
# 同時插入多條數據:
result=cur.executemany(sql,[("tai","888"),("wus","999")])
# 修改數據
sql="update userinfo set name=%s where id=3"
result=cur.execute(sql,name)
# 刪除數據
sql="delete from userinfo where id=7"
result=cur.execute(sql)
# 一定要提交 坑
conn.commit()
# 關閉遊標和連接
cur.close()
conn.close()
四.查 fetchone fetchmany fetchall
fetchone() 獲取下一行數據,第一次為首行
import pymysql
# 1.連接
conn=pymysql.connect(
host="localhost",
port=3306,
user="root",
password=‘‘,
db="db5",
charset="utf8"
)
# 2.創建遊標
cur=conn.cursor()
sql="select * from userinfo"
cur.execute(sql)
# 查詢第一行的數據
row=cur.fetchone() #獲取下一行
print(row) #(1, ‘alex‘, ‘123‘)
# 查詢第二行的數據
row=cur.fetchone()
print(row) #(3, ‘lili‘, ‘666‘)
# 3.關閉遊標
cur.close()
# 4.關閉連接
conn.close()
fetchall() 獲取所有行數據源
import pymysql
# 1.連接
conn=pymysql.connect(
host="localhost",
port=3306,
user="root",
password=‘‘,
db="db5",
charset="utf8"
)
# 2.創建遊標
cur=conn.cursor()
sql="select * from userinfo"
cur.execute(sql)
# 查詢所有的數據
row=cur.fetchall()
print(row)
# 3.關閉遊標
cur.close()
# 4.關閉連接
conn.close()
fetchmany(4) 獲取4行數據
import pymysql
# 1.連接
conn=pymysql.connect(
host="localhost",
port=3306,
user="root",
password=‘‘,
db="db5",
charset="utf8"
)
# 2.創建遊標
cur=conn.cursor()
sql="select * from userinfo"
cur.execute(sql)
# 查詢三條的數據
row=cur.fetchmany(3)
print(row)
# 3.關閉遊標
cur.close()
# 4.關閉連接
conn.close()
補充:
問題
1. 默認情況下,我們獲取到的返回值是元組,只能看到每行的數據,卻不知道每一列代表的是什麽
解決方案:
使用以下方式來返回字典,每一行的數據都會生成一個字典
在實例化的時候,將屬性cursor設置為pymysql.cursors.DictCursor
示例:
cur=conn.cursor(cursor=pymysql.cursors.DictCursor)
案例:
import pymysql
# 1.連接
conn=pymysql.connect(
host="localhost",
port=3306,
user="root",
password=‘‘,
db="db5",
charset="utf8"
)
# 2.創建遊標
cur=conn.cursor(cursor=pymysql.cursors.DictCursor)
sql="select * from userinfo"
cur.execute(sql)
# 查詢所有的數據
row=cur.fetchall()
print(row)
# [{‘id‘: 1, ‘name‘: ‘alex‘, ‘password‘: ‘123‘}, {‘id‘: 3, ‘name‘: ‘lili‘, ‘password‘: ‘666‘}, {‘id‘: 4, ‘name‘: ‘tai‘, ‘password‘: ‘888‘}, {‘id‘: 5, ‘name‘: ‘wus‘, ‘password‘: ‘999‘}, {‘id‘: 6, ‘name‘: ‘lili -- hhk‘, ‘password‘: ‘666‘}]
# 3.關閉遊標
cur.close()
# 4.關閉連接
conn.close()
問題2:
在fetchone示例中,在獲取行數據的時候,可以理解開始的時候,有一個行指針指著第一行的上方,獲取一行,它就向下移動一行,
# 所以當行指針到最後一行的時候,就不能再獲取到行的內容,所以我們可以使用如下方法來移動行指針:
解決方案:
cursor.scroll(1,mode=‘relative‘) # 相對當前位置移動
cursor.scroll(2,mode=‘absolute‘) # 相對絕對位置移動
第一個值為移動的行數,整數為向下移動,負數為向上移動,mode指定了是相對當前位置移動,還是相對於首行移動
# 1.連接
conn=pymysql.connect(
host="localhost",
port=3306,
user="root",
password=‘‘,
db="db5",
charset="utf8"
)
# 2.創建遊標
cur=conn.cursor(cursor=pymysql.cursors.DictCursor)
sql="select * from userinfo"
cur.execute(sql)
# 查詢所有的數據
row=cur.fetchone()
print(row)
#相對位置
cur.scroll(-1,mode=‘relative‘)#設置之後,光標相對於當前位置往前移動了一行
row=cur.fetchone()
print(row)
#絕對位置
cur.scroll(3,mode=‘absolute‘)#設置之後,光標相對於絕對位置往下運動相應量.
row=cur.fetchone()
print(row)
# 3.關閉遊標
cur.close()
# 4.關閉連接
conn.close()
python pymsql的用法 180903