• python操控mysql


     选取操作的模块 pymysql

    # pymysql连接数据库的必要参数:主机、端口、用户名、密码、数据库
    # 注:pymysql不能提供创建数据库的服务,数据库要提前创建
    import pymysql

    # 1)建立数据库连接对象 conn
    # 2)通过 conn 创建操作sql的 游标对象
    # 3)编写sql交给 cursor 执行
    # 4)如果是查询,通过 cursor对象 获取结果
    # 5)操作完毕,端口操作与连接


    # 1)建立数据库连接对象 conn
    conn = pymysql.connect(user='root', passwd='root', database='oldboy')
    # conn = pymysql.connect(user='root', passwd='root', database='oldboy', autocommit=True)

    # 2)通过 conn 创建操作sql的 游标对象
    # 注:游标不设置参数,查询的结果就是数据元组,数据没有标识性
    # 设置pymysql.cursors.DictCursor,查询的结果是字典,key是表的字段
    cursor = conn.cursor(pymysql.cursors.DictCursor)

    # 3)编写sql交给 cursor 执行
    # 创建表
    # sql1 = 'create table t1(id int, x int, y int)'
    # cursor.execute(sql1)

    # 增
    sql2 = 'insert into t1 values(%s, %s, %s)'

    # 增1
    # cursor.execute(sql2, (1, 10, 100))
    # cursor.execute(sql2, (2, 20, 200))
    # 重点:在创建conn对象时,不设置autocommit,默认开启事务,增删改操作不会直接映射到数据库中,
    # 需要执行 conn.commit() 动作
    # conn.commit()

    # 增多
    # cursor.executemany(sql2, [(3, 30, 300), (4, 40, 400)])
    # conn.commit()


    # 删
    # sql3 = 'delete from t1 where id=%s'
    # cursor.execute(sql3, 4)
    # conn.commit()


    # 改
    # sql4 = 'update t1 set y=666 where id=2'
    # cursor.execute(sql4)
    # conn.commit()


    # 查
    sql5 = 'select * from t1'
    row = cursor.execute(sql5) # 返回值是受影响的行
    print(row)

    # 4)如果是查询,通过 cursor对象 获取结果
    # fetchone() 偏移一条取出,fetchmany(n) 偏移n条取出,fetchall() 偏移剩余全部
    r1 = cursor.fetchone()
    print(r1)
    r2 = cursor.fetchone()
    print(r2)
    r3 = cursor.fetchmany(1)
    print(r3)
    r4 = cursor.fetchall()
    print(r4)


    # 5)操作完毕,端口操作与连接
    cursor.close()
    conn.close()
  • 相关阅读:
    【转载】Java的JVM原理
    【转载】Java容器的线程安全
    【转载】Java中的容器讲解
    【转载】Java集合容器全面分析
    【转载】Java多线程
    【转载】Java泛型(一)
    09_dubbo服务发布原理
    07_dubbo_compiler
    06_javassist
    05_dubbo_aop
  • 原文地址:https://www.cnblogs.com/whnbky/p/11650714.html
Copyright © 2020-2023  润新知