python 通过PYMYSQL使用MYSQL数据库方法
什么是MYSQL数据库?
MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS (Relational Database Management System,关系数据库管理系统) 应用软件之一。
什么是PYMYSQL?
PyMySQL 是在 Python3.x 版本中用于连接 MySQL 服务器的一个库,Python2中则使用mysqldb。
PyMySQL 遵循 Python 数据库 API v2.0 规范,并包含了 pure-Python MySQL 客户端库。
PyMySQL安装
pip install pymysql
PyMySQL使用
连接数据库
1、首先导入PyMySQL模块
2、连接数据库(通过connect())
3、创建一个数据库对象 (通过cursor())
4、进行对数据库做增删改查
import pymysql
# 连接数据库
count = pymysql.connect(
host = 'xx.xxx.xxx.xx', # 数据库地址
port = 3306, # 数据库端口号
user='xxxx', # 数据库账号
password='XXXX', # 数据库密码
db = 'test_sll') # 数据库表名# 创建数据库对象
db = count.cursor()
查找数据
-
db.fetchone()获取一条数据
-
db.fetchall()获取全部数据
'''
遇到问题没人解答?小编创建了一个Python学习交流QQ群:531509025
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
import pymysql
# 连接数据库
count = pymysql.connect(
host = 'xx.xxx.xxx.xx', # 数据库地址
port = 3306, # 数据库端口号
user='xxxx', # 数据库账号
password='xxxx', # 数据库密码
db = 'test_sll') # 数据库名称
# 创建数据库对象
db = count.cursor()
# 写入SQL语句
sql = "select * from students "
# 执行sql命令
db.execute(sql)
# 获取一个查询
# restul = db.fetchone()
# 获取全部的查询内容
restul = db.fetchall()
print(restul)
db.close()
修改数据
commit() 执行完SQL后需要提交保存内容
import pymysql
# 连接数据库
count = pymysql.connect(
host = 'xx.xxx.xxx.xx', # 数据库地址
port = 3306, # 数据库端口号
user='xxx', # 数据库账号
password='xxx', # 数据库密码
db = 'test_sll') # 数据库表名
# 创建数据库对象
db = count.cursor()
# 写入SQL语句
sql = "update students set age = '12' WHERE id=1"
# 执行sql命令
db.execute(sql)
# 保存操作
count.commit()
db.close()
删除数据
'''
遇到问题没人解答?小编创建了一个Python学习交流QQ群:531509025
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
import pymysql
# 连接数据库
count = pymysql.connect(
host = 'xx.xxx.xxx.xx', # 数据库地址
port = 3306, # 数据库端口号
user='xxxx', # 数据库账号
password='xxx', # 数据库密码
db = 'test_sll') # 数据库表名
# 创建数据库对象
db = count.cursor()
# 写入SQL语句
sql = "delete from students where age = 12"
# 执行sql命令
db.execute(sql)
# 保存提交
count.commit()
db.close()
新增数据
新增数据这里涉及到一个事务问题,事物机制可以保证数据的一致性,比如插入一个数据,不会存在插入一半的情况,要么全部插入,要么都不插入
import pymysql
# 连接数据库
count = pymysql.connect(
host = 'xx.xxx.xxx.xx', # 数据库地址
port = 3306, # 数据库端口号
user='xxxx', # 数据库账号
password='xxx', # 数据库密码
db = 'test_sll') # 数据库表名
# 创建数据库对象
db = count.cursor()
# 写入SQL语句
sql = "insert INTO students(id,name,age)VALUES (2,'安静','26')"
# 执行sql命令
db.execute(sql)
# 保存提交
count.commit()
db.close()
到这可以发现除了查询不需要保存,其他操作都要提交保存,并且还会发现删除,修改,新增,只是修改了SQL,其他的没什么变化
创建表
创建表首先我们先定义下表内容的字段
字段名 | 含义 | 类型 |
---|---|---|
id | id | varchar |
name | 姓名 | varchar |
age | 年龄 | int |
import pymysql
# 连接数据库
count = pymysql.connect(
host = 'xx.xxx.xxx.xx', # 数据库地址
port = 3306, # 数据库端口号
user='xxxx', # 数据库账号
password='xxx', # 数据库密码
db = 'test_sll') # 数据库表名
# 创建数据库对象
db = count.cursor()
# 写入SQL语句
sql = 'CREATE TABLE students (id VARCHAR(255) ,name VARCHAR(255) ,age INT)'
# 执行sql命令
db.execute(sql)
db.close()
本文来自博客园,作者:I'm_江河湖海,转载请注明原文链接:https://www.cnblogs.com/jhhh/p/16760906.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)