官方的文档在: http://www.sqlalchemy.org/docs/05/mappers.html#advdatamapping_relation_patterns_manytomany
下面我们以blogpost-tag的实例来说明.
首先, metadata:
from datetime import datetime
from sqlalchemy import *
from sqlalchemy.orm import *
engine = create_engine('mysql://root:xxx@localhost/test')
metadata = MetaData(engine)
post和tag的metadata就不贴了.
post_tags_table = Table('post_tags', metadata,
Column('post_id', Integer, ForeignKey('posts.id'), primary_key=True),
Column('keyword_id', Integer, ForeignKey('keywords.id'), primary_key=True)
)
最重要的映射:
mapper(tag, tag_table)
mapper(post, post_table, properties={'tags': relation(tag, secondary=post_tags_table, backref='posts')})
第二行的意思是, 把post对象映射到post_table所代表的表, 在post对象上添加一个tags的属性, 通过post_tags_table对多对关联tag对象.
"backref"是说, 给tag对象上加一个反向通过tag.posts属性找到所有具备此tag的post.
这样可以操作:
session = create_session()
#p = post(user_id=1, title='测测试试', content='测试测试')
#p.tags.append(tag(label='测试'))
#session.add(j)
#session.flush()
jl = session.query(post).all()
for o in jl:
print o
for t in o.tags:
print t
最新评论