Python 操作 MySQL 数据库

利用PyMySQL连接MySQL

连接数据库

复制
import pymysql
# 连接MySQL MySQL在本地运行 用户名为root 密码为123456 默认端口3306
db = pymysql.connect(host='localhost', user='root', password='123456', port=3306)
# cursor()方法获得MySQL的操作游标,利用游标来执行SQL语句,其中执行方法为execute()
cursor = db.cursor()
# 获取MySQL的当前版本
cursor.execute('SELECT VERSION()')
# fetchone()方法获得第一条数据,即版本号
data = cursor.fetchone()
print('Database version:', data)
# 创建一个名为reptile的数据库,默认编码为utf8mb4
cursor.execute("CREATE DATABASE reptile DEFAULT CHARACTER SET utf8mb4")
db.close()
# 运行输出:
Database version: ('8.0.16',)
# 运行生成一个名为reptile的数据库

创建表

复制
import pymysql
db = pymysql.connect(host='localhost', user='用户名', password='密码', port=3306, db='reptile')
cursor = db.cursor()
sql = '''CREATE TABLE
IF NOT EXISTS students
(
id VARCHAR(255) NOT NULL,
name VARCHAR(255) NOT NULL,
age INT NOT NULL,
PRIMARY KEY (id)
)'''
# 创建一个名为students的数据表,主键为id
cursor.execute(sql)
db.close()
# 运行创建一个数据表

插入数据

方式1

复制
import pymysql
id = '20180001'
user = 'Lee Hua'
age = 20
# 连接数据库
db = pymysql.connect(host='localhost', user='用户名', password='密码', port=3306, db='reptile')
# 获得MySQL的操作游标
cursor = db.cursor()
sql = '''INSERT INTO students(id, name, age) VALUES(%s %s %s)'''
try:
# 执行
cursor.execute(sql, (id, user, age))
# 数据插入、更新、删除操作,都需要用到commit()方法才能生效
db.commit()
except:
# 调用rollback()执行数据回滚,相当于什么都没有发生过
db.rollback()
db.close()
# 运行,数据被插入到数据表中

方式2

复制
import pymysql
db = pymysql.connect(host='localhost', user='用户名', password='密码', port=3306, db='reptile')
cursor = db.cursor()
data = {
'id': '20180002',
'user': 'Lao wang',
'age': 19
}
table_name = 'students'
keys = ', '.join(data.keys()) # id, user, age
values = ', '.join(['%s'] * len(data)) # ['%s', '%s', ......] len(data)个'%s'
sql = '''INSERT INTO {table_name}({keys}) VALUES({values})'''.format(table_name=table_name, keys=keys, values=values)
# sql = INSERT INTO students(id, name, age) VALUES(%s %s %s)
try:
tuple_ = tuple(data.values())
if cursor.execute(sql, tuple_):
print('成功插入数据')
db.commit()
except:
print('插入数据失败')
db.rollback()
db.close()

更新数据

复制
import pymysql
db = pymysql.connect(host='localhost', user='用户名', password='密码', port=3306, db='reptile')
cursor = db.cursor()
sql = 'UPDATA students SET age = %s WHERE name = %s'
try:
cursor.execute(sql, (25, 'Bob'))
db.commit()
except:
db.rollback()
db.close()

实现去重(如果数据存在,则更新数据;如果数据不存在,则插入数据。)

复制
import pymysql
db = pymysql.connect(host='localhost', user='用户名', password='密码', port=3306, db='reptile')
cursor = db.cursor()
data = {
'id': '20180002',
'user': 'Lao wang',
'age': 19
}
table_name = 'students'
keys = ', '.join(data.keys()) # keys = id, name, age
values = ', '.join(['%s'] * len(data)) # values = %s, %s, %s
update = ', '.join(
[" {key} = %s".format(key=key) for key in data]
) # id = %s, name = %s, age = %s
sql = '''INSERT INTO {table_name}({keys}) VALUES({values}) ON DUPLICATE KEY update'''.format(table_name=table_name, keys=keys, values=values)
# ON DUPLICATE KEY UPDATE 表示:如果主键已经存在,那么就执行更新操作
try:
tuple_ = tuple(data.values())
if cursor.execute(sql, tuple_):
print('成功插入数据')
db.commit()
except:
print('插入数据失败')
db.rollback()
db.close()

删除数据

复制
import pymysql
db = pymysql.connect(host='localhost', user='用户名', password='密码', port=3306, db='reptile')
cursor = db.cursor()
table = 'students'
condition = 'age > 20'
sql = 'DELETE FROM {table} WHERE {conditon}'.format(table=table, conditon=condition)
try:
cursor.execute(sql)
db.commit()
except:
db.rollback()
db.close()
# 删除age > 20的数据

查询数据

复制
import pymysql
db = pymysql.connect(host='localhost', user='用户名', password='密码', port=3306, db='reptile')
cursor = db.cursor()
sql = 'SELECT * FROM students WHERE age >= 20'
try:
cursor.execute(sql)
print('Count:', cursor.rowcount) # 调用cursor的rowcount属性,获取查询结果的条数
one = cursor.fetchone() # 获取结果的第一条信息
print('One:', one)
result = cursor.fetchall() # 获取结果的所有数据
print('Result:', result)
print('Result Type:', type(result))
for row in result:
print(row)
except:
print('Error')
复制
# 输出:
Count: 0
One: None
Result: ()
Result Type: <class 'tuple'>

一次性查询所有数据

复制
import pymysql
db = pymysql.connect(host='localhost', user='用户名', password='密码', port=3306, db='reptile')
cursor = db.cursor()
sql = 'SELECT * FROM students WHERE age >= 20'
try:
cursor.execute(sql)
print('Count:', cursor.rowcount) # 调用cursor的rowcount属性,获取查询结果的条数
row = cursor.fetchone() # 获取结果的第一条数据
while row:
print('Row:', row)
row = cursor.fetchone()
except:
print('Error')
posted @   LeeHua  阅读(639)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· winform 绘制太阳,地球,月球 运作规律
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 上周热点回顾(3.3-3.9)
点击右上角即可分享
微信分享提示

目录导航