简体   繁体   English

在SQLAlchemy中使用sum()和unnest()

[英]Using sum() and unnest() with sqlalchemy

I'm trying to figure out proper syntax for using sum and unnest , but I have yet to figure out the proper syntax as currently generated SQL is invalid for PostgreSQL: 我正在尝试找出使用sumunnest正确语法,但是由于当前生成的SQL对PostgreSQL无效,因此我还没有找出正确的语法:

sqlalchemy.exc.ProgrammingError: (ProgrammingError) could not determine polymorphic type because input has type "unknown"
 'SELECT (SELECT sum(foo) AS sum_1 \nFROM unnest(%(unnest_1)s) AS foo) AS anon_1 \nFROM products' {'unnest_1': 'stock'}

Working SQL would be: 有效的SQL将是:

SELECT (SELECT sum(foo) AS sum_1 FROM unnest(stock) AS foo) AS anon_1 FROM products;

Example test script is here: 示例测试脚本在这里:

from sqlalchemy import Column, Integer, select
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import create_engine
from sqlalchemy.orm import sessionmaker
from sqlalchemy.dialects.postgresql import ARRAY

from sqlalchemy import func as F
from sqlalchemy.sql import column

import logging

Base = declarative_base()

db = create_engine('postgresql://scott:tiger@localhost/')

# create a configured "Session" class
Session = sessionmaker(bind=db)
session = Session()

logging.basicConfig()

class P(Base):
    __tablename__ = 'products'

    id = Column(Integer, primary_key=True)
    stock = Column(ARRAY(Integer, dimensions=1))
    total = Column(Integer)


    def __init__(self, stock=[]):
        self.stock = stock
        self.total = 0

if __name__ == '__main__':
    Base.metadata.create_all(db)

    session.add_all([P([1, 2]), P([0, 0]), P([0, 2])])
    session.commit()

    _q = select([F.sum(column('foo'))]) \
        .select_from(F.unnest('stock').alias('foo')).as_scalar()

    q = select([_q]).select_from(P.__table__)

    print session.execute(q).fetchall()

stock needs to be a column: stock必须为一栏:

F.unnest(P.stock)

You passed a string bind argument. 您传递了一个字符串绑定参数。

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM