侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

Python实现连接MySql数据库及增删改查操作详解

Python  /  管理员 发布于 7年前   191

本文实例讲述了Python实现连接MySql数据库及增删改查操作。分享给大家供大家参考,具体如下:

在本文中介绍 Python3 使用PyMySQL连接数据库,并实现简单的增删改查。(注意是python3)

1、安装PyMySQL

PyMySQL 是在 Python3.x 版本中用于连接 MySQL 服务器的一个库,Python2中则使用mysqldb。PyMySQL 遵循 Python 数据库 API v2.0 规范,并包含了 pure-Python MySQL 客户端库。在使用 PyMySQL 之前,我们需要确保 PyMySQL 已安装。

① 使用pip命令安装

pip install PyMySQL

② 如果你的系统不支持 pip 命令,可以使用以下git方式安装

//使用git下载安装包$ git clone https://github.com/PyMySQL/PyMySQL$ cd PyMySQL/$ python3 setup.py install

2、Python连接MySql数据库

连接数据库前,请先确认以下事项:

Ⅰ 在你的机子上已经安装了 Python MySQLdb 模块。
Ⅱ 您已经创建了数据库 test
Ⅲ 连接数据库test使用的用户名为 root,密码为 root,你可以可以自己设定或者直接使用root用户名及其密码。

# *===================================*# * Created by Zhihua_w.# * Author: Wei ZhiHua# * Date: 2017/1/10 0003# * Time: 下午 2:28# * Project: PYTHON STUDY# * Power: DATABASE# *===================================*import pymysql# 打开数据库连接(ip/数据库用户名/登录密码/数据库名)db = pymysql.connect("localhost", "root", "root", "test")# 使用 cursor() 方法创建一个游标对象 cursorcursor = db.cursor()# 使用 execute() 方法执行 SQL 查询cursor.execute("SELECT VERSION()")# 使用 fetchone() 方法获取单条数据.data = cursor.fetchone()print("Database version : %s " % data)# 关闭数据库连接db.close()

3、Python操作MySql数据库实现增删改查

① 数据库插入操作

# *===================================*# * Created by Zhihua_w.# * Author: Wei ZhiHua# * Date: 2017/1/10 0004# * Time: 下午 2:32# * Project: PYTHON STUDY# * Power: DATABASE# *===================================*import pymysql# 打开数据库连接(ip/数据库用户名/登录密码/数据库名)db = pymysql.connect("localhost", "root", "root", "test")# 使用 cursor() 方法创建一个游标对象 cursorcursor = db.cursor()# SQL 插入语句sql = """INSERT INTO user(name)     VALUES ('Mac')"""try:  # 执行sql语句  cursor.execute(sql)  # 提交到数据库执行  db.commit()except:  # 如果发生错误则回滚  db.rollback()# 关闭数据库连接db.close()

② 数据库查询

# *===================================*# * Created by Zhihua_w.# * Author: Wei ZhiHua# * Date: 2017/1/10 0005# * Time: 下午 2:39# * Project: PYTHON STUDY# * Power: DATABASE# *===================================*import pymysql# 打开数据库连接(ip/数据库用户名/登录密码/数据库名)db = pymysql.connect("localhost", "root", "root", "test")# 使用 cursor() 方法创建一个游标对象 cursorcursor = db.cursor()# SQL 查询语句sql = "SELECT * FROM user"try:  # 执行SQL语句  cursor.execute(sql)  # 获取所有记录列表  results = cursor.fetchall()  for row in results:    id = row[0]    name = row[1]    # 打印结果    print("id=%s,name=%s" % \    (id, name))except:  print("Error: unable to fecth data")# 关闭数据库连接db.close()

③ 数据库更新

# *===================================*# * Created by Zhihua_w.# * Author: Wei ZhiHua# * Date: 2017/1/10 0005# * Time: 下午 2:39# * Project: PYTHON STUDY# * Power: DATABASE# *===================================*import pymysql# 打开数据库连接(ip/数据库用户名/登录密码/数据库名)db = pymysql.connect("localhost", "root", "root", "test")# 使用 cursor() 方法创建一个游标对象 cursorcursor = db.cursor()# SQL 更新语句sql = "UPDATE user SET name = 'Bob' WHERE id = 1"try:  # 执行SQL语句  cursor.execute(sql)  # 提交到数据库执行  db.commit()except:  # 发生错误时回滚  db.rollback()# 关闭数据库连接db.close()

④ 数据库删除

# *===================================*# * Created by Zhihua_w.# * Author: Wei ZhiHua# * Date: 2017/1/10 0006# * Time: 下午 2:49# * Project: PYTHON STUDY# * Power: DATABASE# *===================================*import pymysql# 打开数据库连接(ip/数据库用户名/登录密码/数据库名)db = pymysql.connect("localhost", "root", "root", "test")# 使用 cursor() 方法创建一个游标对象 cursorcursor = db.cursor()# SQL 删除语句sql = "DELETE FROM user WHERE id = 1"try:  # 执行SQL语句  cursor.execute(sql)  # 提交修改  db.commit()except:  # 发生错误时回滚  db.rollback()# 关闭数据库连接db.close()

更多关于Python相关内容感兴趣的读者可查看本站专题:《Python常见数据库操作技巧汇总》、《Python数学运算技巧总结》、《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》、《Python入门与进阶经典教程》及《Python文件与目录操作技巧汇总》

希望本文所述对大家Python程序设计有所帮助。


  • 上一条:
    python接口自动化(十六)--参数关联接口后传(详解)
    下一条:
    Python3.6实现带有简单界面的有道翻译小程序
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 在python语言中Flask框架的学习及简单功能示例(0个评论)
    • 在Python语言中实现GUI全屏倒计时代码示例(0个评论)
    • Python + zipfile库实现zip文件解压自动化脚本示例(0个评论)
    • python爬虫BeautifulSoup快速抓取网站图片(1个评论)
    • vscode 配置 python3开发环境的方法(0个评论)
    • 近期文章
    • 在windows10中升级go版本至1.24后LiteIDE的Ctrl+左击无法跳转问题解决方案(0个评论)
    • 智能合约Solidity学习CryptoZombie第四课:僵尸作战系统(0个评论)
    • 智能合约Solidity学习CryptoZombie第三课:组建僵尸军队(高级Solidity理论)(0个评论)
    • 智能合约Solidity学习CryptoZombie第二课:让你的僵尸猎食(0个评论)
    • 智能合约Solidity学习CryptoZombie第一课:生成一只你的僵尸(0个评论)
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2018-04
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2022-01
    • 2023-07
    • 2023-10
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客