热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Python操作MySQL(pymysql模块)详解及示例代码

本文介绍了使用Python操作MySQL数据库的方法,详细讲解了pymysql模块的安装和连接MySQL数据库的步骤,并提供了示例代码。内容涵盖了创建表、插入数据、查询数据等操作,帮助读者快速掌握Python操作MySQL的技巧。


目录

python连接mysql数据库

操作表与数据




详解

python连接mysql数据库


pymysql是一个第三方模块,需要通过pip install pymysql进行安装。



    import pymysql


    # 连接mysql数据库
    cOnn= pymysql.connect(host='mysql服务器ip',
                          port='mysql服务器端口(默认为3306)',
                          user='mysql服务器用户名',
                          password='mysql服务器用户密码',  
                          database='mysql服务器数据库',
                          charset='utf8')  # 注意:charset='utf8' 不能写成utf-8




    # 使用 cursor()方法 创建一个游标对象 cursor
    cursor = conn.cursor()  # 创建一个游标对象,查询返回元组
    cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)  # 创建一个游标对象,查询返回字典,占用空间多

    (左右滑动查看完整python代码)




    操作表与数据


    创建表


      import pymysql


      # 连接mysql数据库
      cOnn= pymysql.connect(host='mysql服务器ip',
                            port='mysql服务器端口(默认为3306)',
                            user='mysql服务器用户名',
                            password='mysql服务器用户密码',
                            database='mysql服务器数据库',
                            charset='utf8')




      # 使用 cursor()方法 创建一个游标对象 cursor
      cursor = conn.cursor()  # 创建一个游标对象,查询返回元组
      # cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)  # 创建一个游标对象,查询返回字典,占用空间多




      # 使用 execute()方法 执行sql,如果表存在则删除
      cursor.execute("DROP TABLE IF EXISTS user")


      # 创建表
      sql = '''CREATE TABLE user (
              NAME CHAR(20) NOT NULL,
              AGE INT,  
              SEX CHAR(1),
              INCOME FLOAT)'''


      # 执行sql
      cursor.execute(sql)


      # 关闭游标
      cursor.close()


      # 关闭数据库连接
      conn.close()

      (左右滑动查看完整python代码)




      操作数据(查询)


        import pymysql


        # 连接mysql数据库
        cOnn= pymysql.connect(host='mysql服务器ip',
                              port='mysql服务器端口(默认为3306)',
                              user='mysql服务器用户名',
                              password='mysql服务器用户密码',
                              database='mysql服务器数据库',
                              charset='utf8')




        # 使用 cursor()方法 创建一个游标对象 cursor
        cursor = conn.cursor()  # 创建一个游标对象,查询返回元组
        # cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)  # 创建一个游标对象,查询返回字典,占用空间多




        sql = "SELECT * FROM user WHERE INCOME > %s" % (1000)
        try:
           cursor.execute(sql)  # 执行SQL语句
           print(cursor.rowcount)  # 获取查出多少行结果
           print(cursor.fetchone())  # 获取一条结果
           print(cursor.fetchmany(10))  # 获取10条结果
           print(cursor.fetchall())  # 获取全部结果
        except Exception as e:
           print(f"SQL执行失败:{e}")




        # 关闭游标
        cursor.close()


        # 关闭数据库连接
        conn.close()

        (左右滑动查看完整python代码)




        操作数据(增删改)


          import pymysql


          # 连接mysql数据库
          cOnn= pymysql.connect(host='mysql服务器ip',
                                port='mysql服务器端口(默认为3306)',
                                user='mysql服务器用户名',
                                password='mysql服务器用户密码',
                                database='mysql服务器数据库',
                                charset='utf8')


          cursor = conn.cursor()  # 创建一个游标对象


          # 增
          sql = "INSERT INTO user(NAME,AGE, SEX, INCOME) \
                VALUES (%s,  %s,  %s,  %s )" % \
                ('pamela', 18, 'F', 1000)


          # 删
          sql = "DELETE FROM user WHERE AGE > %s" % (20)


          # 改
          sql = "UPDATE user SET AGE = AGE + 1 WHERE SEX = '%s'" % ('M')


          try:
             cursor.execute(sql)  # 执行SQL语句
             conn.commit()  # 提交到数据库执行,对存储的数据修改后需要commit
          except Exception as e:
             print(f"SQL执行失败:{e}")
             conn.rollback()  # 如果发生错误则回滚




          cursor.close()  # 关闭游标


          conn.close()  # 关闭数据库连接

          (左右滑动查看完整python代码)




          注意:sql注入问题


          给sql语句传参数,要注意sql注入的问题,传参数不要通过字符串拼接,要通过execute方法来传。


            import pymysql


            # 连接mysql数据库
            cOnn= pymysql.connect(host='mysql服务器ip',
            port='mysql服务器端口(默认为3306)',
            user='mysql服务器用户名',
            password='mysql服务器用户密码',
            database='mysql服务器数据库',
            charset='utf8')
            cursor = conn.cursor() # 创建一个游标对象,查询返回元组


            # sql = "SELECT * FROM user WHERE INCOME > %s" % (1000)
            sql = "SELECT * FROM user WHERE INCOME > %s"
            try:
            cursor.execute(sql, (1000,)) # 执行SQL语句,在第二个参数中传参(把所有参数放在一个元组中)
            except Exception as e:
            print(f"SQL执行失败:{e}")




            cursor.close() # 关闭游标


            conn.close() # 关闭数据库连接

            (左右滑动查看完整python代码)




            其他


            数据备份


              语法:
              备份数据(在cmd命令行直接执行)
              mysqldump -h服务器 -u用户名 -p密码 数据库名 > 备份文件.sql




              #单库备份
              mysqldump -h127.0.0.1 -uroot -p123 db1 > db1.sql
              mysqldump -h127.0.0.1 -uroot -p123 db1 table1 table2 > db1-table1-table2.sql


              #多库备份
              mysqldump -h127.0.0.1 -uroot -p123 --databases db1 db2 db3 > db1_db2_db3.sql


              #备份所有库
              mysqldump -h127.0.0.1 -uroot -p123 --all-databases > all.sql

              (左右滑动查看完整内容)




              数据恢复


                语法:
                恢复数据(在mysql中执行命令)
                切换到一个要备份的数据库中
                source 备份文件.sql




                #方法一:
                命令行:
                mysql -uroot -p123 all.sql


                #方法二:
                mysql中:
                use db1;
                SET SQL_LOG_BIN=0;   #关闭二进制日志,只对当前session生效
                source /root/db1.sql

                (左右滑动查看完整内容)




                事务和锁


                  begin;  # 开启事务
                  select * from user where NAME = 'pamela' for update;  # 查询,for update添加行级锁(select语句后面加一个for update)
                  update user set INCOME=10000 where NAME = 'pamela'; # 完成更新
                  commit;  # 提交事务,释放行级锁

                  (左右滑动查看完整内容)






                  推荐阅读
                  • 深入理解 SQL 视图、存储过程与事务
                    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
                  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
                  • Windows服务与数据库交互问题解析
                    本文探讨了在Windows 10(64位)环境下开发的Windows服务,旨在定期向本地MS SQL Server (v.11)插入记录。尽管服务已成功安装并运行,但记录并未正确插入。我们将详细分析可能的原因及解决方案。 ... [详细]
                  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
                  • 本文深入探讨 MyBatis 中动态 SQL 的使用方法,包括 if/where、trim 自定义字符串截取规则、choose 分支选择、封装查询和修改条件的 where/set 标签、批量处理的 foreach 标签以及内置参数和 bind 的用法。 ... [详细]
                  • 本文详细介绍了如何通过多种编程语言(如PHP、JSP)实现网站与MySQL数据库的连接,包括创建数据库、表的基本操作,以及数据的读取和写入方法。 ... [详细]
                  • 本文详细介绍了IBM DB2数据库在大型应用系统中的应用,强调其卓越的可扩展性和多环境支持能力。文章深入分析了DB2在数据利用性、完整性、安全性和恢复性方面的优势,并提供了优化建议以提升其在不同规模应用程序中的表现。 ... [详细]
                  • 本文介绍了如何在 DB2 环境中创建和删除数据库编目。创建编目是连接新数据库的必要步骤,涉及获取数据库连接信息、使用命令行工具进行配置,并验证连接的有效性。删除编目则用于移除不再需要的数据库连接。 ... [详细]
                  • 本文详细介绍了如何使用libpq库与PostgreSQL后端建立连接。通过探讨PQconnectdb()函数的工作原理及其在实际应用中的使用方法,帮助读者理解并掌握建立高效、稳定的数据库连接的关键步骤。 ... [详细]
                  • 构建基于BERT的中文NL2SQL模型:一个简明的基准
                    本文探讨了将自然语言转换为SQL语句(NL2SQL)的任务,这是人工智能领域中一项非常实用的研究方向。文章介绍了笔者在公司举办的首届中文NL2SQL挑战赛中的实践,该比赛提供了金融和通用领域的表格数据,并标注了对应的自然语言与SQL语句对,旨在训练准确的NL2SQL模型。 ... [详细]
                  • 本文详细介绍了Akka中的BackoffSupervisor机制,探讨其在处理持久化失败和Actor重启时的应用。通过具体示例,展示了如何配置和使用BackoffSupervisor以实现更细粒度的异常处理。 ... [详细]
                  • 网络攻防实战:从HTTP到HTTPS的演变
                    本文通过一系列日记记录了从发现漏洞到逐步加强安全措施的过程,探讨了如何应对网络攻击并最终实现全面的安全防护。 ... [详细]
                  • 解读MySQL查询执行计划的详细指南
                    本文旨在帮助开发者和数据库管理员深入了解如何解读MySQL查询执行计划。通过详细的解析,您将掌握优化查询性能的关键技巧,了解各种访问类型和额外信息的含义。 ... [详细]
                  • 优化ListView性能
                    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
                  • SQL中UPDATE SET FROM语句的使用方法及应用场景
                    本文详细介绍了SQL中UPDATE SET FROM语句的使用方法,通过具体示例展示了如何利用该语句高效地更新多表关联数据。适合数据库管理员和开发人员参考。 ... [详细]
                  author-avatar
                  青藤摄影876
                  这个家伙很懒,什么也没留下!
                  PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
                  Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有