use*_*540 8 python attributes sqlalchemy metaclass dynamic
我使用:Python 2.6和sqlalchemy 0.6.1
这就是我想要做的:
from sqlalchemy.types import (
Integer,
String,
Boolean
)
from sqlalchemy.ext.declarative import declarative_base
Base = declarative_base()
class SampleMeta(type):
def __new__(cls, name, bases, attrs):
attrs.update({ 'id': Column('Id', Integer, primary_key=True),
'name': Column('Name', String),
'description': Column('Description', String),
'is_active': Column('IsActive', Boolean)
})
return super(SampleMeta, cls).__new__(cls, name, bases, attrs)
class Sample(Base):
__tablename__ = 'Sample'
__table_args__ = {'useexisting': True}
__metaclass__ = SampleMeta
def __init__(self, id, name, description, is_active):
self.id = id
self.name = name
self.description = description
self.is_active = is_active
def __repr__(self):
return "<(%d, '%s', '%s', %r)>" % (self.id, self.name, self.description, self.isactive)
Run Code Online (Sandbox Code Playgroud)
我得到的错误是这样的:
TypeError: Error when calling the metaclass bases
metaclass conflict: the metaclass of a derived class must be a (non-strict) subclass of the metaclasses of all its bases
Run Code Online (Sandbox Code Playgroud)
现在,如果我通过使用上面做同样的事情
class Sample(object)
Run Code Online (Sandbox Code Playgroud)
代替
class Sample(Base)
Run Code Online (Sandbox Code Playgroud)
它工作得很好.
我需要动态更新类的属性.所以,我将使用动态属性和列名称.我需要上面的代码才能工作才能到达那里.
请帮忙
要使用元类,DeclaredMeta在这种情况下它必须从Declaratives派生.但是这个用例不需要元类.使用mixins:
from sqlalchemy.types import (
Integer,
String,
Boolean
)
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import Column
Base = declarative_base()
class SampleMixin(object):
id = Column("Id", Integer, primary_key=True)
name = Column("Name", String)
description = Column("Description", String)
is_active = Column("IsActive", Boolean)
class Sample(SampleMixin, Base):
__tablename__ = 'Sample'
__table_args__ = {'useexisting': True}
def __init__(self, id, name, description, is_active):
self.id = id
self.name = name
self.description = description
self.is_active = is_active
def __repr__(self):
return "<(%d, '%s', '%s', %r)>" % (self.id, self.name,
self.description, self.isactive)
from sqlalchemy import select
print select([Sample.id, Sample.name])
Run Code Online (Sandbox Code Playgroud)