码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 使用python操作mysql数据库


    1. 前言

    mysql是一款开源的数据库软件,具有免费特性。

    本篇主要记录 使用python操作mysql数据库的代码。

    预先装好了mysql 8.0.31 和 Navicat Premium 16 。

    2.安装PyMySQL并连接数据库

    由于 MySQL服务器以独立的进程运行,并通过网络对外发布,所以,需要支持python的  MySQL驱动来连接到 MySQL服务器。在python中支持MySQL的数据库模块很多,我选择是使PyMySQL。

    安装PyMySQL可以cmd命令(pip install PyMySQL)安装,也可以pycharm一键安装。

    操作MySQL数据库的方式和SQLite相似。在安装数据库时设置了数据库的用户名和密码,现在就通过以上信息,使用connect()方式连接MySQL数据库,代码如下:

    1. import pymysql
    2. # 打开数据库连接,参数1:主机名或IP;参数2:用户名;参数3:密码;参数4:数据库名称
    3. db = pymysql.connect(host='localhost', user='root', password='root', db='')
    4. # 使用 cursor() 方法创建一个游标对象 cursor
    5. cursor = db.cursor()
    6. # 使用 execute() 方法执行 SQL 查询
    7. cursor.execute("SELECT VERSION()")
    8. # 使用 fetchone() 方法获取单条数据.
    9. data = cursor.fetchone()
    10. print("Database version : %s " % data)
    11. # 关闭数据库连接
    12. db.close()

    执行结果:

    1. Database version : 8.0.31
    2. Process finished with exit code 0

    有关pymysql的其他用法可以查看:pymysql详解(connect连接、游标cursor、获取查询结果集、获取实时数据、解决查询数据为历史数据问题、insert into需要注意的地方)_XC_SunnyBoy的博客-CSDN博客_pymysql获取查询结果

    3. 创建数据库表

    数据库连接成功后,接下来就可以为数据库创建数据库表了。

    创建数据库表使用execute()方法,这里使用该方法在“pythontest_db_name”数据库中创建一个books图书表,books图书表包含id\name\category\price\publish_time 5个字段。

    如果数据库中已经存在了books,那么先删除books,然后再创建books数据库表,代码如下:

    1. import pymysql
    2. # 打开数据库连接
    3. db = pymysql.connect(host='localhost', user='root', password='root', db='pythontest_db_name')
    4. # 使用 cursor() 方法创建一个游标对象 cursor
    5. cursor = db.cursor()
    6. # 使用 execute() 方法执行 SQL,如果表存在则删除
    7. cursor.execute("DROP TABLE IF EXISTS books")
    8. # 使用预处理语句创建表
    9. sql = """
    10. CREATE TABLE books (
    11. id int(8) NOT NULL AUTO_INCREMENT,
    12. name varchar(50) NOT NULL,
    13. category varchar(50) NOT NULL,
    14. price decimal(10,2) DEFAULT NULL,
    15. publish_time date DEFAULT NULL,
    16. PRIMARY KEY (id)
    17. ) ENGINE=MyISAM AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;
    18. """
    19. # 执行SQL语句
    20. cursor.execute(sql)
    21. # 关闭数据库连接
    22. db.close()

    执行结果:

    打开navicat,发现pythontest_db_name数据库下多了一个books表。

     

    4.操作MySQL数据表

    MySQL数据表的操作主要是数据的增删改查,与操作SQLite类似。代码如下:

    1. import pymysql
    2. # 打开数据库连接
    3. db = pymysql.connect(host='localhost', user='root', password='root', db='pythontest_db_name')
    4. # db = pymysql.connect("localhost", "root", "root", "mrsoft",charset="utf8")
    5. # 使用cursor()方法获取操作游标
    6. cursor = db.cursor()
    7. # 数据列表
    8. data = [("book1", 'Python', '55.5', '2022-11-5'),
    9. ("book2", 'Python', '66.6', '2022-11-5'),
    10. ("book2", 'Python', '77.7', '2022-11-5'),
    11. ]
    12. try:
    13. # 执行sql语句,插入多条数据
    14. cursor.executemany("insert into books(name, category, price, publish_time) values (%s,%s,%s,%s)", data)
    15. # 提交数据
    16. db.commit()
    17. except:
    18. # 发生错误时回滚
    19. db.rollback()
    20. # 关闭数据库连接
    21. db.close()

    执行结果:

     


    5. 后续补充

  • 相关阅读:
    Web前端-Vue2+Vue3基础入门到实战项目-Day2(指令补充, computed计算属性, watch侦听器, 水果购物车)
    Go学习第十一章——协程goroutine与管道channel
    Docker极简入门:使用Docker-Compose 搭建redis集群
    查看文件的二进制数据
    开发累了就摸个鱼,帮我修改一下中式英语
    Visual Studio Code的安装和使用
    又又又反转啦!OpenAI吵架吃瓜复盘(1);天才Ilya的精神世界;谷歌帝国的辉煌与腐朽;微软中文提示词教程;Agent是什么 | ShowMeAI日报
    基于SpringBoot的校园失物招领系统
    【SA8295P 源码分析】130 - GMSL2 协议分析 之 I2C/UART 双向控制通道原理分析
    ELK日志保留7天-索引生命周期策略
  • 原文地址:https://blog.csdn.net/qq_33163046/article/details/127704049
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号