【发布时间】:2016-10-19 03:14:04
【问题描述】:
我正在尝试查询Version,我希望在其max_version_number 属性等于version_number 的位置取回对象:
latest_versions = \
dbSession.query(Version).filter(Version.max_version_number == Version.number_version)
这会导致错误:
Traceback (most recent call last):
...
...
filter(Version.max_version_number == Version.version_number).\
File "c:\python27\lib\site-packages\sqlalchemy\orm\query.py", line 2588, in all
return list(self)
File "c:\python27\lib\site-packages\sqlalchemy\orm\query.py", line 2736, in __iter__
return self._execute_and_instances(context)
File "c:\python27\lib\site-packages\sqlalchemy\orm\query.py", line 2751, in _execute_and_instances
result = conn.execute(querycontext.statement, self._params)
File "c:\python27\lib\site-packages\sqlalchemy\engine\base.py", line 914, in execute
return meth(self, multiparams, params)
File "c:\python27\lib\site-packages\sqlalchemy\sql\elements.py", line 323, in _execute_on_connection
return connection._execute_clauseelement(self, multiparams, params)
File "c:\python27\lib\site-packages\sqlalchemy\engine\base.py", line 1010, in _execute_clauseelement
compiled_sql, distilled_params
File "c:\python27\lib\site-packages\sqlalchemy\engine\base.py", line 1146, in _execute_context
context)
File "c:\python27\lib\site-packages\sqlalchemy\engine\base.py", line 1341, in _handle_dbapi_exception
exc_info
File "c:\python27\lib\site-packages\sqlalchemy\util\compat.py", line 200, in raise_from_cause
reraise(type(exception), exception, tb=exc_tb, cause=cause)
File "c:\python27\lib\site-packages\sqlalchemy\engine\base.py", line 1139, in _execute_context
context)
File "c:\python27\lib\site-packages\sqlalchemy\engine\default.py", line 450, in do_execute
cursor.execute(statement, parameters)
sqlalchemy.exc.ProgrammingError: (psycopg2.ProgrammingError) can't adapt type 'property' [SQL: 'SELECT "Versions".id AS "Versions_id", "Links".id AS "Links_id", "Entities".id AS "Entities_id", "SimpleEntities".stalker_version AS "SimpleEntities_stalker_version", "SimpleEntities".id AS "SimpleEntities_id", "SimpleEntities".entity_type AS "SimpleEntities_entity_type", "SimpleEntities".name AS "SimpleEntities_name", "SimpleEntities".description AS "SimpleEntities_description", "SimpleEntities".created_by_id AS "SimpleEntities_created_by_id", "SimpleEntities".updated_by_id AS "SimpleEntities_updated_by_id", "SimpleEntities".date_created AS "SimpleEntities_date_created", "SimpleEntities".date_updated AS "SimpleEntities_date_updated", "SimpleEntities".type_id AS "SimpleEntities_type_id", "SimpleEntities".generic_text AS "SimpleEntities_generic_text", "SimpleEntities".thumbnail_id AS "SimpleEntities_thumbnail_id", "SimpleEntities".html_style AS "SimpleEntities_html_style", "SimpleEntities".html_class AS "SimpleEntities_html_class", "Links".original_filename AS "Links_original_filename", "Links".full_path AS "Links_full_path", "Versions".task_id AS "Versions_task_id", "Versions".take_name AS "Versions_take_name", "Versions".version_number AS "Versions_version_number", "Versions".is_published AS "Versions_is_published", "Versions".created_with AS "Versions_created_with", "Versions".parent_id AS "Versions_parent_id" \nFROM "SimpleEntities" JOIN "Entities" ON "SimpleEntities".id = "Entities".id JOIN "Links" ON "Entities".id = "Links".id JOIN "Versions" ON "Links".id = "Versions".id \nWHERE "Versions".version_number = %(version_number_1)s'] [parameters: {'version_number_1': <property object at 0x00000000060EF6D8>}]
我做错了什么?
Here's Version 模型。
这是我的实际查询,没有问题:
proj_id = 5
versions = Version.query.join(Task).filter(Task.project_id == proj_id).all()
...但是,它返回 all 版本,我希望只获得从查询返回的最高版本号的版本,这也是我尝试过滤的原因.
【问题讨论】:
-
您的问题中没有包含模型
Version。 -
@IljaEverilä 我该怎么做?
-
我的意思是你应该在你的问题中包含
class Version(...):的来源。错误有点清楚,来源不是。 -
没关系,
WHERE "Versions".version_number = %(version_number_1)s'就足够了:Version.max_version_number是@property,不是吗?你在.filter(Version.max_version_number == Version.number_version)中传递属性描述符Version.max_version_number,这当然是疯了。 -
Here's 模型。嗯。关于传递属性描述符......你会建议我做什么?
标签: python postgresql sqlalchemy psycopg2