当前位置: 首页 > news >正文

Pymysql之Cursor常用API

Cursor常用API

1、cursor.execute(query, args=None):执行sql语句。

参数:    

query (str):sql语句。

args (tuple, list or dict):sql语句中如果有变量,或者格式化输出,会在这里填充数据。

Returns:返回一个int值,表示sql语句影响到的行数。

下面演示插入数据的四种方式:

import pymysql.cursors
# 连接数据库
connect = pymysql.connect(
    host='127.0.0.1',
    user='root',
    password='123',
    db='demo_temp',
    charset='utf8',
    cursorclass=pymysql.cursors.DictCursor
)
with connect.cursor() as cursor:   # 创建游标
    # 第一种方式向表中插入数据
    sql = """
        INSERT INTO users (user,passwd) VALUES ('123','123')
        """
    cursor.execute(sql)
    # 第二种方式向表中插入数据
    sql = """
           INSERT INTO users (user,passwd) VALUES (%s,%s)
           """
    cursor.execute(sql,['456','456'])
    # 第三种方式向表中插入数据
    sql = """
               INSERT INTO users (user,passwd) VALUES (%s,%s)
               """
    cursor.execute(sql, ('789', '789'))
    # 第四种方式向表中插入数据
    sql = """
               INSERT INTO users (user,passwd) VALUES (%(a)s,%(b)s)  
               """
    cursor.execute(sql, {'a':'abc','b':'123'})  # 这里的'a'和'b'要和上面VALUES中对应
    connect.commit()  # 插入数据后必须更新
    # 查询数据
    sql = """
        select * from users
        """
    cursor.execute(sql)
    ret = cursor.fetchall()  # 提取查询数据
    print(ret)
connect.close()   # 关闭数据库连接

2、cursor.executemany(query, args):可以执行多条sql语句。

参数:    

query :sql语句

args:可迭代对象

Returns:返回sql语句影响到的行数。

下面是方法实例:

import pymysql.cursors
# 连接数据库
connect = pymysql.connect(
    host='127.0.0.1',
    user='root',
    password='123',
    db='demo_temp',
    charset='utf8',
    cursorclass=pymysql.cursors.DictCursor
)
with connect.cursor() as cursor:   # 创建游标
    # 插入多条数据
    sql = """
               INSERT INTO users (user,passwd) VALUES (%s,%s)  
               """
    ret_row = cursor.executemany(sql,[['a','123'],['b','234'],['c','456']])  # 在args中传入一个可迭代对象。
    connect.commit()  # 插入数据后必须更新
    print(f'当前受影响了{ret_row}行')
    # 查询数据
    sql = """
        select * from users
        """
    cursor.execute(sql)
    ret = cursor.fetchall()  # 提取查询数据
    print(ret)
connect.close()   # 关闭数据库连接

3、cursor.fetchone():从查询语句中获取一条查询结果。

4、cursor.fetchall():获取所有查询到的结果。

5、cursor.fetchmany(size):根据size获取相应的行数。

6、cursor.mogrify(query, args=None):返回执行的sql语句,下面是示例:

import pymysql.cursors
# 连接数据库
connect = pymysql.connect(
    host='127.0.0.1',
    user='root',
    password='123',
    db='demo_temp',
    charset='utf8',
    cursorclass=pymysql.cursors.DictCursor
)
with connect.cursor() as cursor:   # 创建游标
    sql = """
        select * from users
        """
    cursor.execute(sql)
    ret_sql = cursor.mogrify(sql)   # 返回执行的sql语句
    cursor.fetchmany(2)             # 提取查询数据
    print(ret_sql)
connect.close()   # 关闭数据库连接

7、cursor.close():关闭游标,关闭游标后,游标内所有数据将被清空。

相关文章:

  • 【Android新版本兼容】onBackPressed()方法被弃用的解决方案
  • FPS游戏框架漫谈第二十天
  • kafka客户端生产者消费者kafka可视化工具(可生产和消费消息)
  • android retrofit上传List集合数据
  • 矩阵的正定(positive definite)性质的作用
  • 【C++】基础知识讲解(引用、内联、auto,基于范围for循环)
  • 计算机网络——网络
  • 手写分布式存储系统v0.3版本
  • 二分查找------蓝桥杯
  • 【React】如何使antd禁用状态的表单输入组件响应点击事件?
  • 电力负荷预测 | 基于LSTM、TCN的电力负荷预测(Python)
  • Redisson看门狗机制
  • HomeAssistant系统添加HACS插件商店与远程控制家中智能家居
  • php 函数三
  • 【Java基础】Java如何正确判断字符串是否为空
  • 第一章 RocketMQ 概述
  • 关于RabbitMQ常见的十道面试题
  • 人工智能|深度学习——使用多层级注意力机制和keras实现问题分类
  • 安卓动态链接库文件体积优化探索实践
  • Elasticsearch的Index Lifecycle Management(ILM)
  • 特色业务多点开花,苏州银行擦亮金融为民底色
  • 明查|这是“C919迫降在农田”?实为飞机模型将用于科普体验
  • 云南禄丰尾矿坍塌事故搜救正在进行,被掩埋的四辆工程车已找到
  • 抗战回望18︱《广西学生军》:“广西的政治基础是青年”
  • 库里22分赢下抢七大战,火箭十年难破“火勇大战”的魔咒
  • 黔西市游船倾覆事故发生后,贵州省气象局进入特别工作状态