1. 首页
  2. 编程语言
  3. Python
  4. django执行原始查询sql,并返回Dict字典例子

django执行原始查询sql,并返回Dict字典例子

上传者: 2022-03-19 04:31:55上传 PDF文件 102.12 KB 热度 14次

很多时候执行sql语句,数据比django的model来的快,但并不想关心返回的字段,例如你可以执行:select * from product这种sql,这里个方法将会返回与数据库列名相同的键值对 ,格式是这样子的:。返回一串json数据,是不是很完美。。。在使用django的时候,有些需求需要特别高的查询效率,所以需要使用原生的sql语句查询,但是查询结果一般是一个元组嵌套元组。base.py最后在django项目的settings.py文件里修改数据库配置的数据库引擎测试输出结果。所以只需要重写create_cursor方法,就可以更改游标返回的数据类型了。django.db.backends.mysql.base.DatabaseWrapper类中的create_cursor方法如下:到这里,理论上已经完成了重写目标,但是在测试的时候出错了,在django.db.backends.mysql.features.DatabaseFeatures里的is_sql_auto_is_null_enabled方法报出KeyError的错误。原因是is_sql_auto_is_null_enabled方法使用了重写后的游标,cursor.execute返回的结果不是元组,而是一个字典。

下载地址
用户评论