python 操作MySQL数据库

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: python 操作MySQL数据库

文章目录


1. 安装 PyMySQL

2. 连接对象

3. 游标对象

4. 增删改操作

cursor.execute(sql)

cursor.executemany(sql, seq_of_params)

5. 查询操作

6. ORM编程

常用 python ORM 库

learning from 《python web开发从入门到精通》


1. 安装 PyMySQL


conda 虚拟环境下安装 pip install pymysql


2. 连接对象


创建连接的一个 object

import pymysql
try:
    connection = pymysql.connect(
        host='localhost',
        user='root',
        password='123456',
        db='michaeldata',
        charset='utf8',
        cursorclass=pymysql.cursors.DictCursor  # 游标类型
    )
    print("连接成功:", connection)
except Exception as e:
    print("连接失败:", e)

输出:连接成功: <pymysql.connections.Connection object at 0x00000205AC8E96D0>


成功连接后,获取的连接对象,有很多方法,常用的如下:


cursor() 获取游标对象,操作数据库

commit() 提交事务

rollback() 回滚事务

close() 关闭数据库连接


3. 游标对象


cursor = connection.cursor()

游标对象的常用方法:


execute(operation, [, param]) 执行数据库操作,SQL语句

executemany(operation, 参数序列) 批量执行操作

fetchone() 获取查询结果集里的下一条

fetchmany(size) 获取指定数量的记录

fetchall() 获取所有记录

close() 关闭游标

操作流程实例:

import pymysql
try:
    connection = pymysql.connect(
        host='localhost',
        user='root',
        password='123456',
        db='michaeldata',
        charset='utf8',
        cursorclass=pymysql.cursors.DictCursor  # 游标类型
    )
    print("连接成功:", connection)
except Exception as e:
    print("连接失败:", e)
# sql 语句
sql = '''
create table books(
    id int not null auto_increment,
    name varchar(255) not null,
    category varchar(50) not null,
    price decimal(10, 2) default '0',
    publish_time date default null,
    primary key (id)
) engine = InnoDB auto_increment=1 
default charset = utf8mb4 collate = utf8mb4_0900_ai_ci;
'''
cursor = connection.cursor()  # 获取游标对象
cursor.execute(sql)  # 执行sql语句
cursor.close()  # 先关闭游标
connection.close()  # 再关闭连接,或者使用 with as

image.png


4. 增删改操作


  • 对于 增删改 ,使用 cursor.execute() 执行 SQL 语句后,默认不会自动提交,要使用 connection.commit() 提交
  • insert 语句使用 %s 作为占位符,可以防止 SQL注入

cursor.execute(sql)

import pymysql
try:
    connection = pymysql.connect(
        host='localhost',
        user='root',
        password='123456',
        db='michaeldata',
        charset='utf8',
        cursorclass=pymysql.cursors.DictCursor  # 游标类型
    )
    print("连接成功:", connection)
except Exception as e:
    print("连接失败:", e)
# sql 语句
sql = '''
create table if not exists books(
    id int not null auto_increment,
    name varchar(255) not null,
    category varchar(50) not null,
    price decimal(10, 2) default '0',
    publish_time date default null,
    primary key (id)
) engine = InnoDB auto_increment=1 
default charset = utf8mb4 collate = utf8mb4_0900_ai_ci;
'''
cursor = connection.cursor()  # 获取游标对象
cursor.execute(sql)  # 执行sql语句
sql1 = 'insert into books(name, category, price, publish_time) values("python web开发", "python", "98.8", "2020-01-01")'
cursor.execute(sql1)  # 执行sql语句
connection.commit()  # connection 提交才能生效
cursor.close()  # 先关闭游标
connection.close()  # 再关闭连接,或者使用 with as

image.png


cursor.executemany(sql, seq_of_params)

批量操作

import pymysql
try:
    connection = pymysql.connect(
        host='localhost',
        user='root',
        password='123456',
        db='michaeldata',
        charset='utf8',
        cursorclass=pymysql.cursors.DictCursor  # 游标类型
    )
    print("连接成功:", connection)
except Exception as e:
    print("连接失败:", e)
# sql 语句
sql = '''
create table if not exists books(
    id int not null auto_increment,
    name varchar(255) not null,
    category varchar(50) not null,
    price decimal(10, 2) default '0',
    publish_time date default null,
    primary key (id)
) engine = InnoDB auto_increment=1 
default charset = utf8mb4 collate = utf8mb4_0900_ai_ci;
'''
cursor = connection.cursor()  # 获取游标对象
cursor.execute(sql)  # 执行sql语句
# sql1 = 'insert into books(name, category, price, publish_time) values("python web开发", "python", "98.8", "2020-01-01")'
# cursor.execute(sql1)  # 执行sql语句
# connection.commit()  # connection 提交才能生效
# 数据列表
data = [("零基础学Python", 'Python', '79.80', '2018-5-20'),
        ("Python从入门到精通", 'Python', '69.80', '2018-6-18'),
        ("零基础学PHP", 'PHP', '69.80', '2017-5-21'),
        ("PHP项目开发实战入门", 'PHP', '79.80', '2016-5-21'),
        ("零基础学Java", 'Java', '69.80', '2017-5-21'),
        ]
try:
    cursor.executemany('insert into books(name, category, price, publish_time) values(%s, %s, %s, %s)', data)
    connection.commit()  # connection 提交才能生效
except Exception as e:
    connection.rollback()  # 回滚
cursor.close()  # 先关闭游标
connection.close()  # 再关闭连接,或者使用 with as

image.png


5. 查询操作


  • 执行 select 查询,生成结果集,然后使用 fetchone/fetchmany/fetchall () 相关语句获取记录
import pymysql
try:
    connection = pymysql.connect(
        host='localhost',
        user='root',
        password='123456',
        db='michaeldata',
        charset='utf8',
        cursorclass=pymysql.cursors.DictCursor  # 游标类型
    )
    print("连接成功:", connection)
except Exception as e:
    print("连接失败:", e)
# sql 语句
sql = "select * from books order by price"
with connection.cursor() as cursor:
    cursor.execute(sql)  # 执行sql语句
    result1 = cursor.fetchone()  # 获取查询结果
    result2 = cursor.fetchall()  # 获取查询结果
print(result1)
print("*" * 10)
for res in result2:
    print(res)
connection.close()  # 关闭连接

输出结果:

连接成功: <pymysql.connections.Connection object at 0x00000216C72696D0>
{'id': 5, 'name': 'Python从入门到精通', 'category': 'Python', 'price': Decimal('69.80'), 'publish_time': datetime.date(2018, 6, 18)}
**********
{'id': 6, 'name': '零基础学PHP', 'category': 'PHP', 'price': Decimal('69.80'), 'publish_time': datetime.date(2017, 5, 21)}
{'id': 8, 'name': '零基础学Java', 'category': 'Java', 'price': Decimal('69.80'), 'publish_time': datetime.date(2017, 5, 21)}
{'id': 4, 'name': '零基础学Python', 'category': 'Python', 'price': Decimal('79.80'), 'publish_time': datetime.date(2018, 5, 20)}
{'id': 7, 'name': 'PHP项目开发实战入门', 'category': 'PHP', 'price': Decimal('79.80'), 'publish_time': datetime.date(2016, 5, 21)}
{'id': 3, 'name': 'python web开发', 'category': 'python', 'price': Decimal('98.80'), 'publish_time': datetime.date(2020, 1, 1)}


6. ORM编程


ORM Object Relational Mapping 对象关系映射


它把 数据库 映射为 对象


table - class

record - object

field - attribute

ORM 示例写法 data = Book.query.all()


好处:


数据模型利于重用代码

有很多现成工具完成预处理,事物等

基于 ORM 的业务代码简单语义好,易理解

不必编写性能不佳的 sql

缺点:


ORM 库不是轻量级工具,学习成本高

复杂的查询,无法表达 或者 性能不如原生SQL

ORM 抽象掉了数据库层,无法了解底层操作,也就无法定制特殊的SQL

常用 python ORM 库

Django ORM,跟 Django 结合紧密

SQLAlchemy比较成熟

Peewee轻量级,基于SQLAlchemy开发

Storm 中型,允许跨数据库查询


相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
1月前
|
关系型数据库 MySQL 数据库连接
python脚本:连接数据库,检查直播流是否可用
【10月更文挑战第13天】本脚本使用 `mysql-connector-python` 连接MySQL数据库,检查 `live_streams` 表中每个直播流URL的可用性。通过 `requests` 库发送HTTP请求,输出每个URL的检查结果。需安装 `mysql-connector-python` 和 `requests` 库,并配置数据库连接参数。
132 68
|
20天前
|
关系型数据库 MySQL 数据库
Python处理数据库:MySQL与SQLite详解 | python小知识
本文详细介绍了如何使用Python操作MySQL和SQLite数据库,包括安装必要的库、连接数据库、执行增删改查等基本操作,适合初学者快速上手。
145 15
|
2月前
|
关系型数据库 MySQL 数据处理
探索Python中的异步编程:从asyncio到异步数据库操作
在这个快节奏的技术世界里,效率和性能是关键。本文将带你深入Python的异步编程世界,从基础的asyncio库开始,逐步探索到异步数据库操作的高级应用。我们将一起揭开异步编程的神秘面纱,探索它如何帮助我们提升应用程序的性能和响应速度。
|
2月前
|
存储 缓存 Shell
你知道 Python 其实自带了小型数据库吗
你知道 Python 其实自带了小型数据库吗
27 2
你知道 Python 其实自带了小型数据库吗
|
2月前
|
Web App开发 SQL 数据库
使用 Python 解析火狐浏览器的 SQLite3 数据库
本文介绍如何使用 Python 解析火狐浏览器的 SQLite3 数据库,包括书签、历史记录和下载记录等。通过安装 Python 和 SQLite3,定位火狐数据库文件路径,编写 Python 脚本连接数据库并执行 SQL 查询,最终输出最近访问的网站历史记录。
47 4
|
2月前
|
SQL 机器学习/深度学习 数据采集
SQL与Python集成:数据库操作无缝衔接22.bijius.com
自动化数据预处理:使用Python库(如Pandas)自动清洗、转换和准备数据,为机器学习模型提供高质量输入。 实时数据处理:集成Apache Kafka或Amazon Kinesis等流处理系统,实现实时数据更新和分析。
|
2月前
|
关系型数据库 MySQL 数据库
Mysql学习笔记(四):Python与Mysql交互--实现增删改查
如何使用Python与MySQL数据库进行交互,实现增删改查等基本操作的教程。
73 1
|
2月前
|
存储 关系型数据库 数据库
轻量级数据库的利器:Python 及其内置 SQLite 简介
轻量级数据库的利器:Python 及其内置 SQLite 简介
74 3
|
2月前
|
SQL 机器学习/深度学习 数据库
SQL与Python集成:数据库操作无缝衔接
在开始之前,确保你已经安装了必要的Python库,如`sqlite3`(用于SQLite数据库)或`psycopg2`(用于PostgreSQL数据库)。这些库提供了Python与SQL数据库之间的接口。
|
2月前
|
SQL 关系型数据库 数据库
使用 PostgreSQL 和 Python 实现数据库操作
【10月更文挑战第2天】使用 PostgreSQL 和 Python 实现数据库操作