zoukankan      html  css  js  c++  java
  • Python操作MySQL数据库

    Windows下安装MySQL

    详细可参考 Windows下MySQL安装流程,8.0以上版本ROOT密码报错及修改

    安装驱动程序

    python想要操作MySQL,必须要有一个中间件,或者叫做驱动程序,驱动程序有很多,mysqlclient、mysqldb、pymysql。我选择用pymysql,安装命令:pip install pymysql

    连接数据库

    import pymysql
    
    db = pymysql.connect(
        host="127.0.0.1",
        user='root',
        password='123456',
        database='pymysql_test',
        port=3306
    )
    
    cursor = db.cursor()
    cursor.execute('select 1')
    
    data = cursor.fetchone()
    print(data)
    
    db.close()
    

    插入数据

    import pymysql
    
    db = pymysql.connect(
        host="127.0.0.1",
        user='root',
        password='123456',
        database='pymysql_test',
        port=3306
    )
    
    cursor = db.cursor()
    
    sql = """
        insert into user(id,username,gender,age,password) values(null,'abc',1,18,'111111');
    """
    
    cursor.execute(sql)
    db.commit()
    db.close()
    

    将数据作为参数的方式插入到数据库

    sql = """
        insert into user(id,username,gender,age,password) values(null,%s,%s,%s,%s);
    """
    
    cursor.execute(sql,('spider',1,20,'222222'))
    

    查找数据

    使用pymysql查询数据,可以使用 fetch 方法

    • fetchone():这个方法每次只获取一条数据
    • fetchall():这个方法接收全部的返回结果
    • fetchmany(size):这个方法可以获取指定条数的数据
    cursor = db.cursor()
    
    sql = """
        select * from user
    """
    
    cursor.execute(sql)
    while True:
        result = cursor.fetchone()
        if not result:
            break
        print(result)
    
    db.close()
    

    直接使用fetchall,一次性可以把所有满足条件的数据都取出来

    cursor = db.cursor()
    
    sql = """
        select * from user
    """
    
    cursor.execute(sql)
    results = cursor.fetchall()
    for result in results:
        print(result)
    
    db.close()
    

    使用fetchmany,指定获取多少条数据

    cursor = db.cursor()
    
    sql = """
        select * from user
    """
    
    cursor.execute(sql)
    results = cursor.fetchmany(1)
    for result in results:
        print(result)
    
    db.close()
    

    删除数据

    cursor = db.cursor()
    
    sql = """
        delete from user where id=1
    """
    
    cursor.execute(sql)
    db.commit()
    
    db.close()
    

    更新数据

    conn = pymysql.connect(
        host="127.0.0.1",
        user='root',
        password='123456',
        database='pymysql_test',
        port=3306
    )
    
    sql = """
        update user set username='aaa' where id=1
    """
    cursor.execute(sql)
    conn.commit()
    
    conn.close()
    
  • 相关阅读:
    c#中String跟string的“区别”<转>
    JS中判断对象是否为空
    report builder地址:http://localhost/reports
    今天开始,主攻MS Dynamics CRM
    IO负载高的来源定位
    ORACL学习笔记 之 分区表
    Linux自动删除n天前日志
    Oracle中NVL2 和NULLIF的用法
    Ubuntu学习笔记之Sqldeveloper安装
    给ubuntu的swap分区增加容量
  • 原文地址:https://www.cnblogs.com/meowv/p/11310569.html
Copyright © 2011-2022 走看看