zoukankan      html  css  js  c++  java
  • pymysql总结

    一、创建数据库

    import pymysql
    conn = pymysql.connect(host='ip', user='root', password='密码')
    # 以字典的形式返回操作结果
    cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)
    sql = "create database db1 default charset utf8"
    cursor.execute(sql)
    cursor.close()
    conn.close()

    二、创建表

    import pymysql
    conn = pymysql.connect(host='ip', user='root', password='密码', db='db1')
    # 以字典的形式返回操作结果
    cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)
    sql = """
    create table students(
        id varchar(20),
        name varchar(20),
        age int
    )engine=innodb default charset=utf8
    """
    cursor.execute(sql)
    cursor.close()
    conn.close()

    注意:创建表时,要设置主键

    create table students(
        id varchar(20) primary key,
        name varchar(20),
        age int
    )engine=innodb default charset=utf8;

    三、操作数据

    1、插入数据

    a、普通版

    import pymysql
    conn = pymysql.connect(host='ip', user='root', password='密码', db='db1')
    # 以字典的形式返回操作结果
    cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)
    num = '10002'
    name = 'ajax'
    age = 25
    sql = "insert into students(id, name, age) values(%s, %s, %s)"
    try:
        cursor.execute(sql, (num, name, age))
        # 插入数据,需要提交连接mysql对象
        conn.commit()
    except Exception as e:
        print(e)
        conn.rollback()
    cursor.close()
    conn.close()

    注意:conn.commit(), 支持事务(innodb)

     b、高级版(灵活版)

    import pymysql
    conn = pymysql.connect(host='ip', user='root', password='密码', db='db1')
    # 以字典的形式返回操作结果
    cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)
    data = {
        'id': '1001',
        'name': 'tom',
        'age': 24
    }
    
    table = 'students'
    keys = ', '.join(data.keys())
    values = ', '.join(['%s'] * len(data.values()))
    # print(keys)
    # print(values)
    sql = "insert into {table}({keys}) values({values})".format(table=table, keys=keys, values=values)
    # print(sql)
    # print(tuple(data.values()))
    try:
        cursor.execute(sql, tuple(data.values()))
        # 插入数据,需要提交连接mysql对象
        print('数据添加成功')
        conn.commit()
    except Exception as e:
        print(e)
        conn.rollback()
    cursor.close()
    conn.close()

    2、更新数据

    a、普通版

    import pymysql
    conn = pymysql.connect(host='ip', user='root', password='密码', db='db1')
    # 以字典的形式返回操作结果
    cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)
    age = 100
    id = '1001'
    
    sql = "update students set age=%s where id=%s"
    
    try:
        cursor.execute(sql, (age, id))
        print('修改数据成功')
        conn.commit()
    except Exception as e:
        print(e)
        conn.rollback()

    b、高级版(灵活版)

    作用:如果数据存在,则更新数据,如果数据不存在,则添加数据

    import pymysql
    
    conn = pymysql.connect(host='ip', user='root', password='密码', db='db1')
    # 以字典的形式返回操作结果
    cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)
    data = {
        'id': '1003',
        'name': 'tom',
        'age': 26
    }
    
    table = 'students'
    keys = ', '.join(data.keys())
    values = ', '.join(['%s'] * len(data.values()))
    # print(keys)
    # print(values)
    sql = "insert into {table}({keys}) values({values}) on duplicate key update".format(table=table, keys=keys,
                                                                                        values=values)
    # print(sql)
    update = ', '.join([" {}= %s".format(key) for key in data])
    # print(update)
    sql = sql + update
    # print(sql)
    # insert into students(id, name, age) values(%s, %s, %s) on duplicate key update id= %s,  name= %s,  age= %s
    # print(tuple(data.values()) * 2)
    try:
        cursor.execute(sql, tuple(data.values()) * 2)
        # 插入数据,需要提交连接mysql对象
        print('数据更新或添加成功')
        conn.commit()
    except Exception as e:
        print(e)
        conn.rollback()
    cursor.close()
    conn.close()

    3、删除数据

    import pymysql
    
    conn = pymysql.connect(host='ip', user='root', password='密码', db='db1')
    # 以字典的形式返回操作结果
    cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)
    
    table = 'students'
    condition = 'age > 30'
    sql = "delete from {table} where {condition}".format(table=table, condition=condition)
    # print(sql)
    
    try:
        cursor.execute(sql)
        print('删除数据成功')
        conn.commit()
    except Exception as e:
        print(e)
        conn.rollback()

    4、查询数据

    import pymysql
    
    conn = pymysql.connect(host='ip', user='root', password='密码', db='db1')
    # 以字典的形式返回操作结果
    cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)
    
    table = 'students'
    condition = 'age > 10'
    sql = "select * from {table} where {condition}".format(table=table, condition=condition)
    # print(sql)
    
    try:
        cursor.execute(sql)
        results = cursor.fetchall()
        print(results)
    except Exception as e:
        conn.rollback()
  • 相关阅读:
    oracle查找前几条记录
    linux主要目录
    openstack搭建3、部署xinetd服务
    openstack搭建1、前期准备
    openstack搭建2、部署Mariadbgalera
    Java 基础(类的加载与ClassLoader的理解)
    K8S 查看资源使用情况
    Java 基础 (Java 反射机制)
    Java 基础 (网络编程 TCP 例子)
    Java 基础 (网络编程 UDP 例子, URL)
  • 原文地址:https://www.cnblogs.com/wt7018/p/11907239.html
Copyright © 2011-2022 走看看