我有一个简单的陈述,
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条记录。这种情况是随意发生的,有时是针对一个用户而有时针对另一个用户。
答案 0 :(得分:1)
退房:
简短回答是你应该使用第一个查询:
for bt in list(Bet.select().where(Bet.match == m)):