Sqlalchemy中的多对多映射

废话不多说.

我是用metadata和class分开的方式来进行映射的. 这样可以最大限度的灵活.(文档里对这块的描述并不是那么清楚, 零零碎碎的)

下面我们以blogpost-tag的实例来说明.

首先, metadata:

  1. from datetime import datetime
  2. from sqlalchemy import *
  3. from sqlalchemy.orm import *
  4. engine = create_engine('mysql://root:xxx@localhost/test')
  5. metadata = MetaData(engine) 
post和tag的metadata就不贴了.

  1. post_tags_table = Table('post_tags', metadata,
  2.     Column('post_id', Integer, ForeignKey('posts.id'), primary_key=True),
  3.     Column('keyword_id', Integer, ForeignKey('keywords.id'), primary_key=True)
  4. )
最重要的映射:

  1. mapper(tag, tag_table)
  2. 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.

这样可以操作:


  1. session = create_session()
  2. #p = post(user_id=1, title='测测试试', content='测试测试')
  3. #p.tags.append(tag(label='测试'))
  4. #session.add(j)
  5. #session.flush()
  6. jl = session.query(post).all()
  7. for o in jl:
  8.     print o
  9.     for t in o.tags:
  10.         print t





  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值