Peewee创建了多个记录(在烧瓶应用程序上)

时间:2014-06-19 23:07:53

标签: python flask peewee flask-peewee

我有一个简单的陈述,

Points.create(user=bt.user,match=m,value=2,datecreated=date.today())

我希望它创建一条记录,但有时会创建多条记录。不知道发生了什么。

完整代码如下:

from utils.models import *
import sys
m = Match.select().where(Match.id == sys.argv[1]).get()
r = Result.select().where(Result.match == m).get()
w= r.winner
print(m.id,m.team1.name,m.team2.name,m.mdate,m.mtime)
if Bet.select().where(Bet.match == m).exists():
           for bt in Bet.select().where(Bet.match == m):
               print("User:::"+str(bt.user.name))
               if w.id == bt.bet.id:
                   print("+2")
                   Points.create(user=bt.user,match=m,value=2,datecreated=date.today())
               else:
                   print("-2")
                   Points.create(user=bt.user,match=m,value=-2,datecreated=date.today())


This is the end result:
(u'Tony George', 2)
(u'AJ', 2)
(u'Tony George', 2)
(u'AJ', 2)
(u'Aravind S', 2)
(u'Iyyam', 2)
(u'Rajakumar', 2)
(u'Leo', 2)

正如你所看到的,它似乎为Tony George创造了2条记录。这种情况是随意发生的,有时是针对一个用户而有时针对另一个用户。

1 个答案:

答案 0 :(得分:1)

退房:

简短回答是你应该使用第一个查询:

for bt in list(Bet.select().where(Bet.match == m)):