0

我有一个简单的说法,

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 条记录。这是任意发生的,有时针对一个用户,有时针对另一个用户。

4

1 回答 1

1

查看:

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

for bt in list(Bet.select().where(Bet.match == m)):
于 2014-06-20T00:43:18.267 回答