如何使用sqlalchemy从查询中返回行?

时间:2017-05-16 15:59:21

标签: python sqlalchemy

使用我当前的代码,我能够返回包含来自给定表(服务器,端口,用户和环境)的所有数据的字典,但是我怎么才能仅返回,例如,仅返回用户和环境?

engine_str = con_string.format(
    login=login, passwd=pwd, hostname=hostname, port=db_port, db=db_name
)

try:
    engine = sqlalchemy.create_engine(engine_str, echo=False)
    session = sessionmaker(bind=engine)
    connection = engine.connect()
    session = session(bind=connection)
    Base = declarative_base()
except exc.SQLAlchemyError:
    raise

def select_data(server, trigger_name):
    _t = Table('trigger_details', Base.metadata, autoload_with=engine)
    try:
        stm = session.query(_t).filter_by(
            server=server, trigger_name=trigger_name
        )
        column = [c["name"] for c in stm.column_descriptions]
        return [dict(zip(column, row)) for row in stm.all()]
    finally:
        session.close()

1 个答案:

答案 0 :(得分:0)

解决:

engine_str = con_string.format(
    login=login, passwd=pwd, hostname=hostname, port=db_port, db=db_name
)

try:
    engine = sqlalchemy.create_engine(engine_str, echo=False)
    session = sessionmaker(bind=engine)
    connection = engine.connect()
    session = session(bind=connection)
    Base = declarative_base()
except exc.SQLAlchemyError:
    raise

def select_data(server, trigger_name):
    _t = Table('trigger_details', Base.metadata, autoload_with=engine)
    try:
        stm = session.query(_t.c.user, _t.c.environment).filter(
            server == server, trigger_name == trigger_name
        )
        column = [c["name"] for c in stm.column_descriptions]
        return [dict(zip(column, row)) for row in stm.all()]
    finally:
        session.close()