我正在使用:SQLAlchemy 0.7.9 和 Python 2.7.3 和 Bottle 0.11.4。我是python的业余爱好者。
我有一个从声明性基础派生的类(有很多列),如下所示:
class Base(object):
@declared_attr
def __tablename__(cls):
return cls.__name__.lower()
id = Column(Integer, primary_key = True)
def to_dict(self):
serialized = dict((column_name, getattr(self, column_name))
for column_name in self.__table__.c.keys())
return serialized
Base = declarative_base(cls=Base)
class Case(Base):
version = Column(Integer)
title = Column(String(32))
plausible_dd = Column(Text)
frame = Column(Text)
primary_task = Column(Text)
secondary_task = Column(Text)
eval_objectives = Column(Text)
...
我目前在Bottle中使用这个“路线”来转储json中的一行/类,如下所示:
@app.route('/<name>/:record')
def default(name, record, db):
myClass = getattr(sys.modules[__name__], name)
parms = db.query(myClass).filter(myClass.id == record)
result = json.dumps(([parm.to_dict() for parm in parms]))
return result
我的第一个问题是:如何让每列都有一些静态文本,我可以将其用作专有名称,以便我可以遍历列并获取它们的值和专有名称?例如:
class Case(Base):
version = Column(Integer)
version.pn = "Version Number"
我的第二个问题是:以下是否符合我的要求?我见过这样的例子,但我不明白解释。
来自sqlalchemy.org的示例:
id = Column("some_table_id", Integer)
我对示例的解释:
version = Column("Version Number", Integer)
显然我不希望创建一个表列。我只是希望该列具有一般意义上的“属性”。先感谢您。