python – 如何使用SQLAlchemy只选择一列?

栏目: Python · 发布时间: 7年前

内容简介:翻译自:https://stackoverflow.com/questions/37133774/how-can-i-select-only-one-column-using-sqlalchemy

我想仅使用“where子句”从我的数据库中选择(并返回)一个字段.代码是:

from sqlalchemy.orm import load_only
    @application.route("/user", methods=['GET', 'POST'])
    def user():
        user_id = session.query(User, User.validation==request.cookies.get("validation")).options(load_only("id"))
        session.commit()
        return user_id

这失败了,回溯是:

File "/Library/Python/2.7/site-packages/flask/app.py", line 1836, in __call__
return self.wsgi_app(environ, start_response)
File "/Library/Python/2.7/site-packages/flask/app.py", line 1820, in wsgi_app
response = self.make_response(self.handle_exception(e))
File "/Library/Python/2.7/site-packages/flask/app.py", line 1403, in handle_exception
reraise(exc_type, exc_value, tb)
File "/Library/Python/2.7/site-packages/flask/app.py", line 1817, in wsgi_app
response = self.full_dispatch_request()
File "/Library/Python/2.7/site-packages/flask/app.py", line 1478, in full_dispatch_request
response = self.make_response(rv)
File "/Library/Python/2.7/site-packages/flask/app.py", line 1577, in make_response
rv = self.response_class.force_type(rv, request.environ)
File "/Library/Python/2.7/site-packages/werkzeug/wrappers.py", line 841, in force_type
response = BaseResponse(*_run_wsgi_app(response, environ))
File "/Library/Python/2.7/site-packages/werkzeug/wrappers.py", line 57, in _run_wsgi_app
return _run_wsgi_app(*args)
File "/Library/Python/2.7/site-packages/werkzeug/test.py", line 867, in run_wsgi_app
app_rv = app(environ, start_response)
TypeError: 'Query' object is not callable

如何选择并返回“id”列?我也尝试了其他几种方法,但也失败了. “load_only”是正确的选项吗?

Query

对象接受要作为位置参数进行查询的实体,因此只需将其传递给User.id:

user_id = session.query(User.id).\
        filter(User.validation == request.cookies.get("validation")).\
        scalar()

如果没有找到行,则 scalar() 返回第一个结果的第一个元素或None.它为多行引发MultipleResultsFound异常.

load_only() 表示只应加载实体的给定的基于列的属性,并且将延迟所有其他属性.如果您以后确实需要整个User模型对象,那么这可能就是您的选择.在这种情况下,您的原始查询必须更改为:

user = session.query(User).\
        filter(User.validation == request.cookies.get("validation")).\
        options(load_only("id")).\
        one()

one() 只返回一个结果或引发异常(0或多于1个结果).如果您接受“无”作为“未找到用户”的有效返回值,请使用 one_or_none() .

请注意,谓词(WHERE子句的条件)不应作为实体传递给Query对象,而是与 filter() 一起添加.

最重要的是,Flask中的视图期望您返回以下其中一个:

>一个有效的响应对象

>一个字符串

> a(响应,状态,标题)元组

>一个WSGI应用程序

除了作为WSGI应用程序的响应对象,字符串或元组之外,该机器还会处理任何其他内容.在原始代码中,由于缺少对scalar()等的调用,因此返回了Query对象,然后将其视为WSGI应用程序.

翻译自:https://stackoverflow.com/questions/37133774/how-can-i-select-only-one-column-using-sqlalchemy


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

JavaScript实战手册

JavaScript实战手册

David Sawyer McFarland / 李强 / 机械工业出版社 / 2009 / 89.00元

在《JavaScript实战手册》中,畅销书作者David McFarland教你如何以高级的方式使用JavaScript,即便你只有很少或者没有编程经验。一旦掌握了这种语言的结构和术语,你将学习如何使用高级的JavaScript工具来快速为站点添加有用的交互,而不是一切从头开始编写脚本。和其他的Missing Manuals图书不同,《JavaScript实战手册》清楚、精炼,手把手地讲解。 ......一起来看看 《JavaScript实战手册》 这本书的介绍吧!

在线进制转换器
在线进制转换器

各进制数互转换器

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具