Python SQLAlchemy-从自动加载表的内部联接映射列子集
我刚刚开始使用SQLAlchemy来处理现有的Postgres DB。我要做的是自动加载两个表,执行内部联接,并将列的子集映射到一个对象。为了完成除最后一部分以外的所有内容,我编写了以下代码:Python SQLAlchemy-从自动加载表的内部联接映射列子集,python,orm,sqlalchemy,Python,Orm,Sqlalchemy,我刚刚开始使用SQLAlchemy来处理现有的Postgres DB。我要做的是自动加载两个表,执行内部联接,并将列的子集映射到一个对象。为了完成除最后一部分以外的所有内容,我编写了以下代码: from sqlalchemy.orm import mapper, sessionmaker from sqlalchemy.sql import join, select engine = create_engine("postgresql://<username>:@localhost
from sqlalchemy.orm import mapper, sessionmaker
from sqlalchemy.sql import join, select
engine = create_engine("postgresql://<username>:@localhost/<DBname>")
metadata = Metadata(engine)
Session = sessionmaker(engine)
profiles = Table('userprofile',metadata,autoload=True)
profilefields = Table('profilefield',metadata,autoload=True)
class DBObj(object):
pass
j = join(profiles,profilefields,profiles.c.fieldid==profilefields.c.fieldid)
mapper(DBObj,j,properties={'fieldid':[profiles.c.fieldid,profilefields.c.fieldid]})
q = session.query(DBObj).all()
我应该如何修改这段代码,以断言我只希望将一些指定的列映射到DBObj?我已经搜索了很多地方,似乎找不到一个例子来说明如何做到这一点 您需要将select映射到所需的列。映射联接会导致sqlalchemy将其转换为相应的select*from:
跳过此块:这只是创建测试夹具
>>> from sqlalchemy.orm import mapper, sessionmaker
>>> from sqlalchemy.sql import join, select
>>> from sqlalchemy import *
>>> # engine = create_engine("postgresql://<username>:@localhost/<DBname>")
... engine = create_engine("sqlite:///:memory:")
>>> engine.execute(r"""
... CREATE TABLE userprofile (
... id integer primary key,
... fieldid integer,
... keep integer,
... discard integer
... )
... """)
<sqlalchemy.engine.base.ResultProxy object at 0x2390d90>
>>> engine.execute(r"""
... CREATE TABLE profilefield (
... id integer primary key,
... fieldid integer,
... keep integer,
... discard integer
... )
... """)
<sqlalchemy.engine.base.ResultProxy object at 0x2390e90>
>>> metadata = MetaData(engine)
>>> Session = sessionmaker(engine)
>>> profiles = Table('userprofile',metadata,autoload=True)
>>> profilefields = Table('profilefield',metadata,autoload=True)
>>> engine.execute(profiles.insert({'fieldid': 1, 'keep': 2, 'discard': 3}))
<sqlalchemy.engine.base.ResultProxy object at 0x23e9750>
>>> engine.execute(profilefields.insert({'fieldid': 1, 'keep': 2, 'discard': 3}))
<sqlalchemy.engine.base.ResultProxy object at 0x23e98d0>
>>> class DBObj(object):
... def __repr__(self):
... return "DBobj" + str(self.__dict__)
...
>>> j = join(profiles,
... profilefields,
... profiles.c.fieldid==profilefields.c.fieldid)
以下是新的部分:
>>> js = select([profiles.c.id,
... profiles.c.keep,
... profilefields.c.keep,
... profiles.c.fieldid,
... profilefields.c.fieldid],
... use_labels=True,
... from_obj=j)
>>> mapper(DBObj,alias(js),properties={'fieldid':[profiles.c.fieldid,profilefields.c.fieldid]})
<Mapper at 0x23e9ad0; DBObj>
>>> q = Session().query(DBObj).all()
>>> q
[DBobj{u'userprofile_keep': 2, u'userprofile_id': 1, '_sa_instance_state': <sqlalchemy.orm.state.InstanceState object at 0x23f08d0>, 'fieldid': 1, u'profilefield_keep': 2}]
非常感谢。这确实很有帮助。