Python操作MySQL(详细版)

Python操作MySQL

一、确定是否安装PyMSQL

复制代码
# 在Python中,要操作MysQL,需要依赖于第三方库:pymysql,先安装:pip install PyMySQL
# 在命令行中:pip list | findstr MySQL 检查是否有pymysql

上图显示没有PyMySQL。需要下载安装

二、准备好数据库

复制代码
host='192.168.102.131',user='root',password='123.com',database='woniusales'

测试是否连接成功:

检测端口号:

三、wireshark监听流量

python 复制代码
# 建立连接
conn = pymysql.connect(host='192.168.102.131',user='root',password='123.com',database='woniusales',charset='utf8')
print(conn.host_info)

监听数据库密码错误的流量包

监听数据库密码正确的流量包

四、以二维元组形式输出

python 复制代码
import pymysql

# 建立连接
conn = pymysql.connect(host='192.168.102.131',user='root',password='123.com',database='woniusales',charset='utf8')
# print(conn.host_info)

# 操作数据库,先定义一个游标对象,默认输出元组形式
cursor = conn.cursor()
# 执行SQL语句
sql = "select username,password,role from user"
cursor.execute(sql)

# 获取结果集
result = cursor.fetchall()
print(result) #输出是元组的形式

for row in result:
    print(row[0],row[1],row[2])

# 关闭连接
conn.close()

流量监听:

查看到查询的SQL语句

五、列表+字典 的格式获取结果集

python 复制代码
import pymysql

# 建立连接
from pymysql.cursors import DictCursor

conn = pymysql.connect(host='192.168.102.131',user='root',password='123.com',database='woniusales',charset='utf8')
# print(conn.host_info)

# #将游标对象定义为字典类型,进而通过 列表+字典 的格式获取结果集
# cursor = conn.cursor()
cursor = conn.cursor(DictCursor)
# 执行SQL语句
sql = "select username,password,role from user"
cursor.execute(sql)

# 获取结果集
result = cursor.fetchall()
# print(result) #输出是元组的形式
for row in result:
    print(row['username'],row['password'])

# 关闭连接
conn.close()

六、更新操作

修改图中密码

python 复制代码
import pymysql

# 建立连接
conn = pymysql.connect(host='192.168.102.131',user='root',password='123.com',database='woniusales',charset='utf8')
cursor = conn.cursor()
# 执行SQL语句,更新操作,比如修改某个用户的信息
# 更新的操作,必须确认提交,两种方式:一种是设置autocommit为True,另外则是在代码中显式提交
sql = "update user set password='wangwu' where userid=5"
cursor.execute(sql)
conn.commit() #显式执行更新操作
# 关闭连接
conn.close()

执行更新语句之后的数据库结果:

七、操作数据库中的信息

python 复制代码
from user_register.common import *

def do_reg():
    username = input("请输入用户名:")
    password = input("请输入密码:")
    phone = input("请输入手机号码:")
    result = query_mysql(f"select username from user where username='{username}'")
    if len(result) == 0:
        update_mysql(f"insert into user(username,password,phone) values('{username}','{password}','{phone}')")
    else:
        print("用户名已经存在,不允许注册。")

if __name__ == '__main__':
    do_reg()

封装SQL语句:

python 复制代码
# 针对数据库连接进行封装操作
def query_mysql(sql):
    conn = pymysql.connect(host='192.168.102.131', user='root', password='123.com', database='test',
                           charset='utf8')
    cursor = conn.cursor(DictCursor)
    cursor.execute(sql)
    result = cursor.fetchall()
    conn.close()
    return result

# 针对数据库连接进行封装操作
def update_mysql(sql):
    conn = pymysql.connect(host='192.168.102.131', user='root', password='123.com', database='test',
                           charset='utf8')
    cursor = conn.cursor(DictCursor)
    cursor.execute(sql)
    conn.commit()
    conn.close()
相关推荐
難釋懷几秒前
Redis分片集群手动故障转移
数据库·redis·缓存
进击的雷神2 分钟前
主办方过滤、展位号模糊提取、多层级官网爬取、缅文编码解码——缅甸塑料展爬虫四大技术难关攻克纪实
网络·爬虫·python
无名-CODING6 分钟前
从零开始!Vue3+SpringBoot前后端分离项目Docker部署实战(上):环境搭建与数据库容器化
数据库·spring boot·docker
向往着的青绿色7 分钟前
雷池(SafeLine)社区版免费部署教程|从环境检查到防护实操全流程
网络·计算机网络·nginx·网络安全·容器·网络攻击模型·信息与通信
_饭团8 分钟前
字符串函数全解析:12 种核心函数的使用与底层模拟实现
c语言·开发语言·学习·考研·面试·蓝桥杯
Larry_Yanan8 分钟前
Qt网络开发之基于 QWebEngine 实现简易内嵌浏览器
linux·开发语言·网络·c++·笔记·qt·学习
winfredzhang9 分钟前
用 Python + DeepSeek AI 构建文件批量重命名与智能管理工具
python·api·重命名·预览·解压·deepseek
2401_8318249615 分钟前
嵌入式C++驱动开发
开发语言·c++·算法
西西弗Sisyphus15 分钟前
Python 中__pycache__文件夹
python
Bdygsl18 分钟前
MySQL(2)—— CRUD
数据库·mysql