Django - Unique Together引发错误。

时间:2018-05-08 02:33:17

标签: django django-models unique-constraint

我正在关注Django应用程序的书籍教程(关键字:TDD,链接:here,作者:Harry Percival),我做了一些小改动,现在破坏了我的代码。

测试

def test_saves_same_game_with_different_players(self):
    player1 = Player.objects.create(name="Player1")
    player2 = Player.objects.create(name="Player2")
    Game.objects.create(player=player1, text="score: other_player")
    game2 = Game.objects.create(player=player2, text="score: other_player")
    game2.full_clean()  # Should not raise.

模型

class Player(models.Model):
  name    = models.TextField(default="")
  objects = models.Manager()

  def __str__(self):
    return self.name

class Game(models.Model):
  player = models.ForeignKey(Player, default=None)
  text   = models.TextField(default="", unique=True)

  objects = models.Manager()

  def __str__(self):
    return self.text

  class Meta:
    ordering = ("id",)
    unique_together = ("player", "text")

错误

...
game2 = Game.objects.create(player=player2, text="score: other_player")
...
IntegrityError: UNIQUE constraint failed: games_game.text

以及sqlite。 在创建具有相同文本的第二个游戏时,错误是unique_together约束。但即使玩家有不同的名字,甚至将名称用作字符串表示,也会发生这种情况。

有人知道如何去做吗?谢谢你的耐心。
干杯。

1 个答案:

答案 0 :(得分:1)

text = models.TextField(默认="",唯一= True)

这是您的代码落入的地方,因为您将文本作为唯一字段。