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)
相关推荐
weixin_468466854 分钟前
Prometheus监控服务部署与实战指南
服务器·后端·python·docker·自动化·prometheus
花酒锄作田10 分钟前
[Python]标准库argparse解析命令行参数使用介绍
python
me83212 分钟前
【Linux】Linux 目录命名规范溯源(Linux各个目录究竟是干嘛的)
linux·运维·数据库
卡次卡次113 分钟前
vibecoding起步之注意点:如何做一个聊天机器人
python·ai
土狗TuGou14 分钟前
SQL内功笔记 · 第2篇:列的约束
数据库·笔记·sql
Hanniel25 分钟前
Python 元类(下):进阶与实战建议
开发语言·python
会编程的土豆28 分钟前
Go interface 底层的 itab 到底是什么
开发语言·后端·golang
java_cj30 分钟前
MySQL 执行原理深度剖析:查询成本计算与优化器内幕
数据库·后端·mysql
java_cj32 分钟前
数据库范式化设计与性能优化全攻略
数据库·后端·性能优化·架构·开源
千纸鹤の脉搏33 分钟前
多线程的初步了解---进程与线程
java·开发语言·学习·线程