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)
相关推荐
淼淼763几秒前
Qt工具栏+图页,图元支持粘贴复制,撤销,剪切,移动,删除
开发语言·c++·windows·qt
爱吃大芒果几秒前
Flutter 本地存储方案:SharedPreferences、SQFlite 与 Hive
开发语言·javascript·hive·hadoop·flutter·华为·harmonyos
Kelvin_Ngan几秒前
Qt包含QtCharts/QValueAxis时编译报错
开发语言·qt
Felven2 分钟前
华为昇腾310P模型转换失败问题解决
linux·python·模型训练·昇腾·310p
葱卤山猪2 分钟前
【Qt】心跳检测与粘包处理:打造稳定可靠的TCP Socket通信
开发语言·数据库·qt
ekprada2 分钟前
Day 41 卷积神经网络(CNN)基础与实战
人工智能·python·机器学习
Dingdangcat864 分钟前
基于改进YOLO11-C2PSA-SEFFN的工业环境气体泄漏检测与定位系统实现
python
AI视觉网奇4 分钟前
live2d 单图转模型 单图生成模型
java·前端·python
a程序小傲5 分钟前
淘宝Java面试被问:Atomic原子类的实现原理
java·开发语言·后端·面试
laocooon5238578867 分钟前
C++中的安全指针(智能指针)
开发语言·c++