a more DRY syntax.
class Foo(Base):
__tablename__ = 'foos'
id = Column(Integer, primary_key=True)
@comparable_using(...), front-ends for synonym and
comparable_property.
+ - Declarative will complete setup for Columns lacking names,
+ allows a more DRY syntax.
+
+ class Foo(Base):
+ __tablename__ = 'foos'
+ id = Column(Integer, primary_key=True)
+
0.4.4
------
- sql
return type.__init__(cls, classname, bases, dict_)
cls._decl_class_registry[classname] = cls
- our_stuff = {}
+ our_stuff = util.OrderedDict()
for k in dict_:
value = dict_[k]
if (isinstance(value, tuple) and len(value) == 1 and
table_kw = {'autoload': True}
else:
table_kw = {}
- cls.__table__ = table = Table(tablename, cls.metadata, *[
- c for c in our_stuff.values() if isinstance(c, Column)
- ], **table_kw)
+ cols = []
+ for key, c in our_stuff.iteritems():
+ if not isinstance(c, Column):
+ continue
+ if c.key is None:
+ c.key = key
+ if c.name is None:
+ c.name = key
+ cols.append(c)
+ cls.__table__ = table = Table(tablename, cls.metadata,
+ *cols, **table_kw)
else:
table = cls.__table__
class Address(Base, Fixture):
__tablename__ = 'addresses'
- id = Column('id', Integer, primary_key=True)
- email = Column('email', String(50))
- user_id = Column('user_id', Integer, ForeignKey('users.id'))
+ id = Column(Integer, primary_key=True)
+ email = Column(String(50), key='_email')
+ user_id = Column('user_id', Integer, ForeignKey('users.id'),
+ key='_user_id')
Base.metadata.create_all()
-
+
+ assert Address.__table__.c['id'].name == 'id'
+ assert Address.__table__.c['_email'].name == 'email'
+ assert Address.__table__.c['_user_id'].name == 'user_id'
+
u1 = User(name='u1', addresses=[
Address(email='one'),
Address(email='two'),