2016-11-22 25 views
0

私は、次の3つのSQL錬金術モデル法my_methodSQLAlchemyでこれらの外部キー関係を照会する方法は?

class MyModelA(db.Model): 
    a_id = db.Column(db.Integer, nullable=False, primary_key=True) 
    my_field1 = db.Column(db.String(1024), unique=True) 

class MyModelB(db.Model): 
    b_id = db.Column(db.Integer, nullable=False, primary_key=True) 
    my_field2 = db.Column(db.String(1024), nullable=True) 

    def my_method(self, arg_my_field1): 
     pass # what goes here?? 

class MyModelC(db.Model, Timestamp): 
    c_id = db.Column(db.Integer, nullable=False, primary_key=True) 
    a_id = db.Column(db.Integer, db.ForeignKey(MyModelA.a_id), default=lambda: MyModelA.query.filter(MyModelA.my_field1 == 'XYZ').one().a_id) 
    a = db.relationship('MyModelA', backref=db.backref('my_model_c')) 
    b_id = db.Column(db.Integer, db.ForeignKey(MyModelB.b_id), nullable=False) 
    b = db.relationship('MyModelB', backref=db.backref('my_model_c')) 
    my_field3 = db.Column(db.String(1024), unique=True) 
    __table_args__ = (db.UniqueConstraint('a_id', 'b_id', name='unique_constraint_aid_bid'),) 

を持って、私はケースとしてmy_field1を持ってMyModelAselfとポイントにMyModelCのインスタンスのmy_field3フィールド(ポイントそれを返すようにしたいです非適合の一致はarg_my_field1)。そのようなインスタンスは最大1つ存在する必要があります。 MyModelCのインスタンスが存在しない場合は、Noneを返します。

その結果を得るには、どのSQLAlchemyクエリをmy_methodに書き込む必要がありますか?ここで

答えて

0

答え

def my_method(self, arg_my_field1): 
    return self.my_model_c.join(MyModelA).filter(MyModelA.my_field1.ilike(arg_my_field1)).one().my_field3 

であることは、以下に示すようMyModelCで2つの関係に追加するlazy='dynamic'が必要です。

class MyModelC(db.Model, Timestamp): 
    c_id = db.Column(db.Integer, nullable=False, primary_key=True) 
    a_id = db.Column(db.Integer, db.ForeignKey(MyModelA.a_id), default=lambda: MyModelA.query.filter(MyModelA.my_field1 == 'XYZ').one().a_id) 
    a = db.relationship('MyModelA', backref=db.backref('my_model_c', lazy='dynamic')) 
    b_id = db.Column(db.Integer, db.ForeignKey(MyModelB.b_id), nullable=False) # MODIFIED 
    b = db.relationship('MyModelB', backref=db.backref('my_model_c', lazy='dynamic')) # MODIFIED 
    my_field3 = db.Column(db.String(1024), unique=True) 
    __table_args__ = (db.UniqueConstraint('a_id', 'b_id', name='unique_constraint_aid_bid')) 
関連する問題