[英]How can SQLAlchemy association_proxy be used bi-directionally?
[英]How to properly use association_proxy and ordering_list together with SQLAlchemy
根据SQLAlchemy Google Group上的一些帖子:
https://groups.google.com/forum/#!topic/sqlalchemy/S4_8PeRBNJw https://groups.google.com/forum/#!topic/sqlalchemy/YRyI7ic1QkY
我假设我可以成功使用assocation_proxy
和ordering_list
扩展来在两个模型之间创建有序的,多对多的关系,例如在下面的Flask / SQLAlchemy代码中:
from flask import Flask
from flask_sqlalchemy import SQLAlchemy
from sqlalchemy.ext.associationproxy import association_proxy
from sqlalchemy.ext.orderinglist import ordering_list
app = Flask(__name__)
app.debug = True
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite://'
db = SQLAlchemy(app)
class Image(db.Model):
__tablename__ = 'images'
id = db.Column(db.Integer, primary_key=True)
filename = db.Column(db.String(255))
class UserImage(db.Model):
__tablename__ = 'user_images'
user_id = db.Column(db.Integer, db.ForeignKey('users.id'), primary_key=True)
image_id = db.Column(db.Integer, db.ForeignKey('images.id'), primary_key=True)
image = db.relationship('Image')
position = db.Column(db.Integer)
class User(db.Model):
__tablename__ = "users"
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.String(255))
_images = db.relationship('UserImage',
order_by='UserImage.position',
collection_class=ordering_list('position'))
images = association_proxy('_images', 'image')
with app.app_context():
db.create_all()
user = User(name='Matt')
user.images.append(Image(filename='avatar.png'))
db.session.add(user)
db.session.commit()
if __name__ == '__main__':
app.run()
但我最终得到以下回溯:
$ python app.py
Traceback (most recent call last):
File "app.py", line 44, in <module>
user.images.append(Image(filename='avatar.png'))
File "/Users/matt/.virtualenvs/sqlalchemy-temp/lib/python2.7/site-packages/sqlalchemy/ext/associationproxy.py", line 595, in append
item = self._create(value)
File "/Users/matt/.virtualenvs/sqlalchemy-temp/lib/python2.7/site-packages/sqlalchemy/ext/associationproxy.py", line 522, in _create
return self.creator(value)
TypeError: __init__() takes exactly 1 argument (2 given)
这是不可能的还是我做了一些公然错误的事情?
sooo close ;-)
请阅读association_proxy
扩展名的创建新值 。
为了使您的代码有效,您也可以
选项-1 :将以下构造函数添加到UserImage
类:
def __init__(self, image):
self.image = image
要么
选项-2 :使用您的函数覆盖默认creator
:
images = association_proxy('_images', 'image',
creator=lambda _i: UserImage(image=_i),
)
我个人赞成后者。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.