Python(pymysql包)操作MySQL【增删改查】

下载pymysql:

pip install pymysql

在MySQL中创建数据库:unicom

sql 复制代码
create database unicom DEFAULT CHARSET utf8 COLLATE utf8_general_ci;

use unicom;

在unicom中创建数据表:admin

sql 复制代码
create table admin(
	id int not null primary key auto_increment,
        username varchar(16) not null,
        password varchar(64) not null,
        mobile char(11) not null
);

1.插入数据

python 复制代码
import pymysql

# 1.连接MySQL
conn = pymysql.connect(host="127.0.0.1", port=3306, user='root', passwd="123456", charset='utf8', db='unicom')
cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)

# 2.发送指令
cursor.execute("insert into admin(username,password,mobile) values('doufuru','DFL123456','1888888888')")
conn.commit()

# 3.关闭
cursor.close()
conn.close()

记得端口号、用户名、用户密码要写对

python中运行成功后,在mysql中查询表中的数据:插入成功

发送指令的代码,还有下面两种方式(最好严格按照下面方式之一进行拼接,即cursor.execute自带的参数方法):

python 复制代码
# 2.发送指令
sql = "insert into admin(username,password,mobile) values(%s,%s,%s)"
cursor.execute(sql,["贯一", "G123456", "1766666666"])
conn.commit()
python 复制代码
# 2.发送指令
sql = "insert into admin(username,password,mobile) values( %(n1)s, %(n2)s, %(n3)s)"
cursor.execute(sql, {"n1": "兰亭", "n2": "L123456", "n3": "1597777777"})
conn.commit()

结果:

2.查询数据

python 复制代码
import pymysql

# 1.连接MySQL
conn = pymysql.connect(host="127.0.0.1", port=3306, user='root', passwd="123456", charset='utf8', db='unicom')
cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)

# 2.发送指令
cursor.execute("select * from admin where id > %s", [2, ])

data_list = cursor.fetchall()
for row_dict in data_list:
    print(row_dict)

conn.commit()

# 3.关闭
cursor.close()
conn.close()

有变化的是发送指令这一步

cursor.fetchall():获取符合条件的所有数据,得到的是[字典,字典,]形式

cursor.fetchone():获取符合条件的第一条数据,字典形式

查询结果:

3.删除数据

python 复制代码
import pymysql

# 1.连接MySQL
conn = pymysql.connect(host="127.0.0.1", port=3306, user='root', passwd="123456", charset='utf8', db='unicom')
cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)

# 2.发送指令
cursor.execute("delete from admin where id=%s", [2, ])
conn.commit()

# 3.关闭
cursor.close()
conn.close()

上面指令是删除id等于2的那一行

运行之前的表数据为:

运行之后的表数据为:

4.修改数据

python 复制代码
import pymysql

# 1.连接MySQL
conn = pymysql.connect(host="127.0.0.1", port=3306, user='root', passwd="123456", charset='utf8', db='unicom')
cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)

# 2.发送指令
cursor.execute("update admin set mobile=%s where id=%s", ["1788888888", 8, ])
conn.commit()

# 3.关闭
cursor.close()
conn.close()

将id为8的mobile修改为1788888888

运行前后数据表:

切记conn.commit()一定不能忘

学习:【最新Python的web开发全家桶(django+前端+数据库)-哔哩哔哩】 https://b23.tv/VtRGLgq

相关推荐
wjhx8 分钟前
QT中对蓝牙权限的申请,整理一下
java·数据库·qt
冰暮流星19 分钟前
javascript之二重循环练习
开发语言·javascript·数据库
万岳科技系统开发44 分钟前
食堂采购系统源码库存扣减算法与并发控制实现详解
java·前端·数据库·算法
冉冰学姐1 小时前
SSM智慧社区管理系统jby69(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·管理系统·智慧社区·ssm 框架
杨超越luckly1 小时前
HTML应用指南:利用GET请求获取中国500强企业名单,揭秘企业增长、分化与转型的新常态
前端·数据库·html·可视化·中国500强
斯普信专业组1 小时前
构建基于MCP的MySQL智能运维平台:从开源服务端到交互式AI助手
运维·mysql·开源·mcp
Elastic 中国社区官方博客1 小时前
Elasticsearch:Workflows 介绍 - 9.3
大数据·数据库·人工智能·elasticsearch·ai·全文检索
仍然.1 小时前
MYSQL--- 聚合查询,分组查询和联合查询
数据库
一 乐1 小时前
校园二手交易|基于springboot + vue校园二手交易系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端
啦啦啦_99991 小时前
Redis-0-业务逻辑
数据库·redis·缓存