我有一个类Item
是id
主键并自动生成。现在我从其他一些外部源读取数据,创建一个Item
对象,并且需要检查这个对象是否已经存在于我的items
表中。我该怎么做?
问问题
18056 次
3 回答
17
最有效的方法是使用exists()
q = session.query(Item.id).filter(Item.email==email)
session.query(q.exists()).scalar() # returns True or False
于 2016-05-15T11:54:52.030 回答
11
您可以查询具有相同属性的项目并检查计数是否大于零。
if session.query(Item.id).filter(Item.email==newItem.email,
Item.type==newItem.type).count() > 0:
// item exists
于 2012-10-05T16:24:49.497 回答
3
您可以尝试类似的方法:
from sqlalchemy import exc
try:
session.add(item)
session.commit()
except exc.IntegrityError:
session.rollback()
print 'This item fails one of the unique/foreign key checks!'
except:
print 'There was another error'
raise
else:
print 'Everything is OK'
这有一个问题,它在提交时起作用,然后回滚......
另一种选择,如果您可以单独检查属性,那么这可能有效:
session.query(Item).filter_by(x=item.x, y=item.y).count() == 0
于 2012-10-05T16:32:15.933 回答