gpt4 book ai didi

python - 如何定义混合表达式?

转载 作者:行者123 更新时间:2023-11-28 23:16:02 24 4
gpt4 key购买 nike

我有两个类,事件和预订。一次事件可以进行多次预订。

class Event(Base):
__tablename__ = 'event'
id = Column(Integer, primary_key=True)
space = Column(Integer)

class Booking(Base):
__tablename_ = 'booking'
id = Column(Integer, primary_key=True)
event_id = Column(Integer, ForeignKey('event.id'))
event = relationship('Event', backref=backref('bookings'))

现在我想计算占用率并决定使用 Event 类的混合属性,如下所示:

@hybrid_property
def occupancy(self):
return float(len(self.bookings)) / float(self.space)

这在某些情况下工作正常,但当我希望能够按占用情况进行过滤时,如下所示:

session.query(Event).filter(Event.occupany > 0.5)

这样做我得到这个错误:

TypeError: object of type 'InstrumentedAttribute' has no len()

所以我意识到我可能需要一个混合表达式并想出了:

@occupancy.expression
def occupancy(cls):
return func.count(select([Booking.id]).where(cls.id == Booking.event_id).label('occupancy')) / cls.space

然而,这会导致 MySQL 错误:

sqlalchemy.exc.ProgrammingError: (_mysql_exceptions.ProgrammingError) 
(1111, 'Invalid use of group function') [SQL: u'SELECT event.id AS
event_id FROM event \nWHERE count((SELECT booking.id \nFROM booking
\nWHERE event.id = booking.event_id)) / event.space > %s']
[parameters: (0.5,)]

如何构建混合表达式?还是有更好的方法来实现我想要的?

最佳答案

计数应在 scalar subquery 内完成.当前查询试图将 count() 函数应用于封闭查询的 WHERE 子句中的子查询的结果集,另一方面,它没有分组,因此您得到错误– 更不用说聚合函数作为谓词属于 HAVING 子句。只需移动调用:

@occupancy.expression
def occupancy(cls):
stmt = select([func.count(Booking.id)]).\
where(cls.id == Booking.event_id).\
label('occupancy')
return stmt / cls.space

关于python - 如何定义混合表达式?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43841866/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com