pymysql操作mysql數(shù)據(jù)庫的方法
前言
本篇博客主要講的是一些基礎(chǔ)的pymysql操作mysql數(shù)據(jù)庫的方法,如果有不足之處,歡迎各位指正
??1、pymysql.connent
用法:創(chuàng)建鏈接
語法:conn = pymysql.connect(host=‘127.0.0.1’, port=端口號, user=‘數(shù)據(jù)庫用戶名’, passwd=‘密碼’, db=‘數(shù)據(jù)庫名’)
conn = pymysql.connect(host='127.0.0.1',
port=3306, user='root', passwd='@123456', db='db4')??2、conn.cursor()
用法:創(chuàng)建光標
cursor = conn.cursor()
游標設(shè)置為字典類型
# 游標設(shè)置為字典類型
cursor = conn.cursor("cursor"=pymysql.cursors.DictCursor)
栗子:
sql = "select * from department;"
# 執(zhí)行sql語句的函數(shù),使用下面函數(shù)進行拼接,防止SQL注入
cursor.execute(sql)
# cursor.scroll(1,mode='relative')
result = cursor.fetchone()
print(result)
輸出結(jié)果:
{'id': 1, 'title': '財務(wù)'}??3、cursor.execute()
用法:執(zhí)行sql語句
cursor.execute(sql)
??4、cursor.executemany()
用法:批量執(zhí)行sql語句
cursor.executemany(sql,[('銷售'), ('經(jīng)理')])??5、cursor.fetchone()
用法:SQL執(zhí)行select默認只是拿一個結(jié)果,多次執(zhí)行該語句可以依次向下拿數(shù)據(jù)
import pymysql
# 創(chuàng)建鏈接,跟socket服務(wù)類似
conn = pymysql.connect(host='127.0.0.1', port=3306,
user='root', passwd='@123456', db='db4')
# 創(chuàng)建游標(相當與創(chuàng)建一個拿數(shù)據(jù)的手)
cursor = conn.cursor()
# 創(chuàng)建要執(zhí)行的SQL語句
sql = "select * from department;"
# 執(zhí)行sql語句的函數(shù),使用下面函數(shù)進行拼接,防止SQL注入
cursor.execute(sql)
result = cursor.fetchone()
print(result)
result = cursor.fetchone()
print(result)
result = cursor.fetchone()
print(result)
# 關(guān)閉鏈接
cursor.close()
conn.close()
·
輸出結(jié)果:
(1, '財務(wù)')
(2, '公關(guān)')
(3, '測試')??6、cursor.scroll()
用法:注:在fetch數(shù)據(jù)時按照順序進行,可以使用cursor.scroll(num,mode)來移動游標位置,如:
- cursor.scroll(1,mode=‘relative’) # 相對當前位置移動
- cursor.scroll(2,mode=‘absolute’) # 相對絕對位置移動
表結(jié)構(gòu):

栗子:
1、 cursor.execute(sql) result = cursor.fetchone() print(result) 輸出結(jié)果: (1, '財務(wù)') 2、 cursor.execute(sql) cursor.scroll(1,mode='absolute') result = cursor.fetchone() print(result) 輸出結(jié)果: (2, '公關(guān)') 3、 cursor.execute(sql) cursor.scroll(1,mode='relative') result = cursor.fetchone() print(result) 輸出結(jié)果: (2, '公關(guān)')
??7、cursor.fetchmany()
用法:可以設(shè)置返回值的個數(shù)cursor.fetchmany(num)
cursor.execute(sql) # cursor.scroll(1,mode='relative') # result = cursor.fetchone() # print(result) result = cursor.fetchmany(2) print(result) 輸出結(jié)果: ((1, '財務(wù)'), (2, '公關(guān)'))
??8、cursor.fetchall()
用法:顧名思義就是拿到所有的結(jié)果
sql = "select * from department;" # 執(zhí)行sql語句的函數(shù),使用下面函數(shù)進行拼接,防止SQL注入 cursor.execute(sql) # cursor.scroll(1,mode='relative') # result = cursor.fetchone() # print(result) # result = cursor.fetchmany(2) # print(result) result = cursor.fetchall() print(result) 輸出結(jié)果: ((1, '財務(wù)'), (2, '公關(guān)'), (3, '測試'), (4, '運維'), (5, '銷售'))
??9、cursor.lastrowid()
用法:獲取新創(chuàng)建數(shù)據(jù)自增ID,如果新增加了多條數(shù)據(jù)只返回最后插入的那條數(shù)據(jù)的自增id
PS:如果只想一個一個拿id只能夠一個一個插入???????
sql = "insert into department(title) values(%s)"
cursor.executemany(sql,[('經(jīng)理')])
# 獲取插入值的自增id
print(cursor.lastrowid)
# 將執(zhí)行的結(jié)果提交到表中,否則表不會發(fā)生變換
conn.commit()
輸出結(jié)果:
6??10、今日練習(xí)
題目要求:
練習(xí):
權(quán)限管理
權(quán)限表:
1、訂單管理
2、用戶管理
3、菜單管理
4、權(quán)限分配
5、Bug管理
用戶表:
1、蔡徐坤
2、雞哥
3、坤哥
用戶關(guān)系權(quán)限表:
1 1
1 2
2 1
Python實現(xiàn):
某個用戶登入后,可以查看自己的所有權(quán)限
題目答案:
【1、創(chuàng)建權(quán)限表】
CREATE TABLE power (
pid INT auto_increment PRIMARY KEY,
purview CHAR(10)
)ENGINE= INNODB DEFAULT CHARSET= utf8;
【2、創(chuàng)建用戶表】
CREATE TABLE users (
uid INT auto_increment PRIMARY KEY,
username CHAR(10)
)ENGINE= INNODB DEFAULT CHARSET= utf8;
【3、創(chuàng)建用戶權(quán)限關(guān)系表】
CREATE TABLE use_pow (
upid INT auto_increment PRIMARY KEY,
power_id INT,
user_id INT,
UNIQUE uq_pid_uid(power_id, user_id),
CONSTRAINT fk_pow FOREIGN KEY (power_id) REFERENCES power(pid),
CONSTRAINT fk_user FOREIGN KEY (user_id) REFERENCES users(uid)
)ENGINE= INNODB DEFAULT CHARSET= utf8;
py文件:
import pymysql
user = input('請輸入用戶名稱>>>')
# 連接數(shù)據(jù)庫
conn = pymysql.connect(host='127.0.0.1', port=3306,
user='root', passwd='@123456', db='db_grant')
# 創(chuàng)建光標
cursor = conn.cursor()
# 查詢是否存在該用戶
sql = "SELECT uid FROM users WHERE username = %(u)s"
cursor.execute(sql, {'u': user})
# 獲取到用戶的id
uid = cursor.fetchone()
# print(uid[0], type(uid[0]))
if uid:
# 這里的%s如果換成%d就會報錯因為execute無論傳入什么類型都要用%s來占位
sql2 = "SELECT purview from power WHERE pid in
(SELECT power_id FROM use_pow WHERE user_id = %s)"
cursor.execute(sql2, uid[0])
result = cursor.fetchall()
print(result)
else:
print("沒有該用戶")
cursor.close()
conn.close()
到此這篇關(guān)于pymysql簡單操作mysql數(shù)據(jù)庫的方法的文章就介紹到這了,更多相關(guān)pymysql操作mysql數(shù)據(jù)庫內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- python?實現(xiàn)?pymysql?數(shù)據(jù)庫操作方法
- python pymysql鏈接數(shù)據(jù)庫查詢結(jié)果轉(zhuǎn)為Dataframe實例
- 使用pymysql查詢數(shù)據(jù)庫,把結(jié)果保存為列表并獲取指定元素下標實例
- python數(shù)據(jù)庫操作mysql:pymysql、sqlalchemy常見用法詳解
- 在python中使用pymysql往mysql數(shù)據(jù)庫中插入(insert)數(shù)據(jù)實例
- Python使用pymysql從MySQL數(shù)據(jù)庫中讀出數(shù)據(jù)的方法
- python3.6使用pymysql連接Mysql數(shù)據(jù)庫
相關(guān)文章
MySQL 遷移后無法快速導(dǎo)數(shù)據(jù)問題解決
這篇文章主要為大家介紹了MySQL 遷移后無法快速導(dǎo)數(shù)據(jù)問題解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-10-10
mysql實現(xiàn)查詢數(shù)據(jù)并根據(jù)條件更新到另一張表的方法示例
這篇文章主要介紹了mysql實現(xiàn)查詢數(shù)據(jù)并根據(jù)條件更新到另一張表的方法,結(jié)合實例形式分析了mysql多表關(guān)聯(lián)查詢、更新等相關(guān)操作技巧,需要的朋友可以參考下2019-03-03
mysql 5.7.5 m15 winx64.zip安裝教程
這篇文章主要為大家詳細介紹了mysql 5.7.5 m15 winx64.zip安裝教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-06-06
MySQL更新存放JSON的字段、\“ 轉(zhuǎn)義成 “的問題描述
本篇介紹在執(zhí)行MySQL線上變更時遇到的問題,表現(xiàn)為"更新JSON字段時,實際更新的值與SQL語句中的值不一致,JSON格式錯誤",本文給大家分享問題描述及解決方案,感興趣的朋友一起看看吧2022-12-12
linux下mysql自動備份數(shù)據(jù)庫與自動刪除臨時文件
mysql自動備份數(shù)據(jù)庫與自動刪除臨時文件,有需要的朋友可以參考下2013-02-02
Ubuntu?服務(wù)器安裝?MySQL?遠程數(shù)據(jù)庫的方法
本篇介紹如何在 Linux 服務(wù)器上安裝 MySQL 數(shù)據(jù)庫,并設(shè)置為可遠程連接,本文通過命令給大家介紹的非常詳細,對Ubuntu?安裝?MySQL遠程數(shù)據(jù)庫感興趣的朋友一起看看吧2022-08-08
CentOS下安裝mysql時忘記設(shè)置root密碼致無法登錄的解決方法
最近在給公司的內(nèi)網(wǎng)開發(fā)用服務(wù)器裝系統(tǒng),然后裝mysql居然就花了一天,原因是因為本人在CentOS下安裝萬mysql后,無法通過root進入,因為安裝的時候,并沒有設(shè)置root密碼而導(dǎo)致無法登錄,通過查找了資料終于解決了,現(xiàn)在想方法分享給大家,有需要的朋友們可以參考借鑒。2016-11-11
與MSSQL對比學(xué)習(xí)MYSQL的心得(六)--函數(shù)
這一節(jié)主要介紹MYSQL里的函數(shù),MYSQL里的函數(shù)很多,我這里主要介紹MYSQL里有而SQLSERVER沒有的函數(shù)2014-08-08

