当前位置: 首页 > 面试题库 >

PyMySQL和OrderedDict

那宏大
2023-03-14
问题内容

我已经使用PyMySQL已有一段时间了,并创建了自己的包装器,用于简化查询的编写。尽管如此,我一直在使用OrderedDict创建CSV文件,因为我需要保持顺序不变,但是我意识到,如果我使用PyMySQL查询数据库,那么我将无法获得数据库所提供的命令。如果我只想转储东西而不是手写订单,那么对CSV文件进行现场检查有点烦人。

我的问题是,如何将PyMySQL与OrderedDict结合使用?目前,我的代码如下:

import pymysql
conn = pymysql.connect(host='localhost', user='root', passwd='', db='test')
cursor = conn.cursor(pymysql.cursors.DictCursor)

因此,无论何时查询,我都会得到一本字典:

cursor.execute("""SELECT * FROM test""")
for row in cursor:
    pp(row)  # gives me dictionary

我想要的是,当我滚动游标时,实际上是按照它们从数据库中传入的顺序来检索这些列的OrderedDict。

就像是:

cursor = conn.cursor(pymysql.cursors.OrderedDict)

问题答案:

您可以使用cursors.DictCursorMixin并将其更改dict_typecollections.OrderedDict(默认值为dict):

from collections import OrderedDict
from pymysql.cursors import DictCursorMixin, Cursor

class OrderedDictCursor(DictCursorMixin, Cursor):
    dict_type = OrderedDict

然后,您可以使用新的游标类,如下所示

cursor = conn.cursor(OrderedDictCursor)


 类似资料:
  • PyMySQL 是一个纯 Python 实现的 MySQL 客户端库,支持兼容 Python 3,用于代替 MySQLdb。 注意:PyMySQL 不支持 _mysql 提供的低级AP I,如data_seek、store_result和use_result。用户应该使用PEP 249中定义的高级 API。但是一些API,比如 autocommit 和 ping,因为 PEP 249 没有涵盖它们的用例,所以支持。

  • 主要内容:创建存储数据表,Pymysql基本使用,修改爬虫程序Python 连接并操作 MySQL 数据库,主要通过 Pymysql 模块实现。本节讲解如何将抓取的数据存储至 MySQL 数据库。 提示:在学习本节知识之前,您已经掌握了 SQL 语言的基本语法。可参考《MySQL教程》 创建存储数据表 首先您应该确定您的计算机上已经安装了 MySQL 数据库,然后再进行如下操作: Pymysql基本使用 1) 连接数据库 参数说明: localhost:本地

  • 本文向大家介绍MySQL适配器PyMySQL详解,包括了MySQL适配器PyMySQL详解的使用技巧和注意事项,需要的朋友参考一下 本文我们为大家介绍 Python3 使用 PyMySQL 连接数据库,并实现简单的增删改查。 什么是 PyMySQL? PyMySQL 是在 Python3.x 版本中用于连接 MySQL 服务器的一个库,Python2中则使用mysqldb。 PyMySQL 遵循

  • 本文向大家介绍pymysql模块的操作实例,包括了pymysql模块的操作实例的使用技巧和注意事项,需要的朋友参考一下 pymysql 模块! pymysql模块时一个第三方模块!需要下载: pymysql的基本使用: 我们可以通过python导入模块来连接数据库,进行登陆注册功能,在使用时sql会遇到注入问题 sql注入问题 利用特殊符号和注释语法 巧妙的绕过真正的sql校验,是用户数据不安全

  • 我创建了一个表,它有一个int类型的默认NULL字段。我需要使用参数查询插入数据,但我无法通过变量将NULL传递到int字段。 我尝试了以下作为返回从mk_int 返回空值 但以上允许在字段中插入NULL。 当我从mk_int返回'NULL'时。。它给出类型不匹配的警告,并插入0而不是NULL

  • 本文向大家介绍C++实现PyMysql的基本功能实例详解,包括了C++实现PyMysql的基本功能实例详解的使用技巧和注意事项,需要的朋友参考一下 用C++实现一个Thmysql类,实现Python标准库PyMysql的基本功能,并提供与PyMysql类似的API,并用pybind11将Thmysql封装为Python库。 PyMysql Thmysql(C++) Thmysql(Python)

  • 问题内容: 我正在尝试使用PyMySQL连接到本地主机上的MySQL: 但是(在Python 2.7和Python 3.2上)我得到了错误: socket.error:[Errno 111]连接被拒绝 pymysql.err.OperationalError:(2003年,“无法连接到’localhost’(111)上的MySQL服务器”) 我确定mysqld正在运行,因为我可以使用command

  • 本文向大家介绍python 3.6 +pyMysql 操作mysql数据库(实例讲解),包括了python 3.6 +pyMysql 操作mysql数据库(实例讲解)的使用技巧和注意事项,需要的朋友参考一下 版本信息:python:3.6  mysql:5.7  pyMysql:0.7.11 测试代码: 测试表: 执行结果: 以上这篇python 3.6 +pyMysql 操作mysql数据库(实