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

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

内容简介:翻译自: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


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

查看所有标签

猜你喜欢:

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

从零开始学创业大全集

从零开始学创业大全集

阳飞扬 / 中国华侨出版社 / 2011-10-1 / 29.80元

为了让每一个怀揣梦想走上创业之路的有志者能在最短的时间内叩开创业的大门,了解创业的流程和方法,从而找到适合自己的创业之路,我们精心编写了这本《从零开始学创业大全集》。阳飞扬编著的《从零开始学创业大全集(超值白金版)》从创业准备、创业团队的组建、创业项目和商业模式的选择、创业计划书的制作、创业资金的筹集、企业的经营策略、资本运作以及产品营销方法、危机应对策略等方面,全面系统地阐述了创业的基本理论与实......一起来看看 《从零开始学创业大全集》 这本书的介绍吧!

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

MD5 加密
MD5 加密

MD5 加密工具

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

Markdown 在线编辑器