sqlalchemy中的内/外连接及立即/延迟加载在mysql, postgresql, db2中的差异处理(by quqi99)

作者:张华  发表于:2014-01-03
版权声明:可以任意转载,转载时请务必以超链接形式标明文章原始出处和作者信息及本版权声明

( http://blog.csdn.net/quqi99 )


见:https://review.openstack.org/#/c/61027/
左连接在postgresql中如果左表的行存在匹配的null值的话,会造成无法有效的对左右连接行加锁,故会报错(在mysql中不会), 所以如下列IPAllocationPool和IPAvailabilityRange两表,
在定义的时候使用左外连接,然后再用options(orm.joinedload('available_ranges', innerjoin=True))将它定义成内连接解决.
class IPAllocationPool():
   # lazy="joined"为左外连接,lazy="select"为内连接,内连接默认是立即加载的策略
   available_ranges = orm.relationship(IPAvailabilityRange, backref='ipallocationpool', lazy="joined", cascade='delete')

allocation_pools = (context.session.query(models_v2.IPAllocationPool).filter_by(subnet_id=subnet_id).options(orm.joinedload('available_ranges', innerjoin=True)).with_lockmode('update'))

但是这样在db2中又会造成问题,因为内连接是立即加载,在db2中,在查询IPAllocationPool时就立即加载了IPAvailabilityRange,然后对IPAvailabilityRange表做合并操作删除了一条记录,那么这时个再来更新IPAllocationPool表就会报错.
所以它又要求我们将其改成延迟加载, 再加"enable_eagerloads(False)"可以解决.



options(orm.noload('available_ranges')))

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

quqi99

你的鼓励就是我创造的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值