Python操作MySQL

因为Python和MySQL是2套软件,所以在互相交互的时候需要一个"桥梁"。这个"桥梁"就是驱动!

  • mysqldb又叫MySQL-python

    • 优点:基于C开发的库,速度快
    • 缺点:在 Windows 平台安装非常不友好,经常出现失败的情况,多年不更新了,只兼容python2
  • mysqlclient

    • 优点:基于C开发的库,速度快,兼容python3
    • 缺点:编译安装可能会导致报各种错误
  • pymysql

    • 优点:纯 Python 实现的驱动,兼容python3,使用简单
    • 缺点:速度不如mysqldb
    【示例】创建数据库
    python 复制代码
    import pymysql
    
    
    # 链接数据库
    con = pymysql.connect(host='localhost',port=3306,user='root',passwd='root',charset='utf8')
    # 获取一个和数据库交互的工具cursor
    coursor = con.cursor()
    # 编写SQL
    sql = '''
    CREATE DATABASE sxt
       DEFAULT CHARACTER SET = 'utf8mb4';
    '''
    # 执行SQL
    coursor.execute(sql)
    # 关闭cursor
    coursor.close()
    # 关闭链接
    con.close()


    *

    python 复制代码
    def add_one():
      # 链接数据库
      con = pymysql.connect(host='localhost',port=3306,user='root',passwd='root',db='sxt',charset='utf8')
      # 获取操作数据的对象 cursor
      cursor = con.cursor()
      # 编写SQL-DML
      # sql = "INSERT INTO t_user VALUES (0,'貂的蝉',18,'女');"
      sql = "INSERT INTO t_user VALUES (0,%s,%s,%s);"
      args = ('刘备',22,'男')
      # 执行SQL
      cursor.execute(sql,args)
      # 提交事务
      con.commit()
      # 关闭Cursor
      cursor.close()
      # 关闭链接
      con.close()
    python 复制代码
    #导入模块
    import pymysql
    #创建连接
    con = pymysql.connect(host='localhost',user='root',password='root',db='db_test',
    charset='utf8')      
    #创建游标对象cursor
    cursor=con.cursor()
    sql='select * from t_user'
    #执行sql
    cursor.execute(sql)
    #获取结果集
    # result = cursor.fetchall()
    # result = cursor.fetchmany(2)
    result = cursor.fetchone()
    print(result)
    # print(cursor.rowcount)
相关推荐
得物技术29 分钟前
破解gh-ost变更导致MySQL表膨胀之谜|得物技术
数据库·后端·mysql
Java水解1 小时前
【MySQL】从零开始学习MySQL:基础与安装指南
后端·mysql
数据智能老司机3 小时前
精通 Python 设计模式——分布式系统模式
python·设计模式·架构
数据智能老司机4 小时前
精通 Python 设计模式——并发与异步模式
python·设计模式·编程语言
数据智能老司机4 小时前
精通 Python 设计模式——测试模式
python·设计模式·架构
数据智能老司机4 小时前
精通 Python 设计模式——性能模式
python·设计模式·架构
c8i5 小时前
drf初步梳理
python·django
每日AI新事件5 小时前
python的异步函数
python
Raymond运维5 小时前
MariaDB源码编译安装(二)
运维·数据库·mariadb
沢田纲吉5 小时前
🗄️ MySQL 表操作全面指南
数据库·后端·mysql