'how can store the number 100 only when 1 to 99 numbers are must have inside the db

suppose i am adding matchround_5, round 1,2,3,4 must have inside the db ,check each round are present in the database , How can i solve this issue?

Modelserializer

class MatchScoreSerializer(serializers.ModelSerializer):

def create(self, validated_data):
    gameevent = validated_data.get('gameevent')
    match_round =validated_data.get('match_round')
    match = Matchscore.objects.filter(gameevent=gameevent,match_round=match_round).first()
    if match :
        validated_data = Matchscore.objects.filter(gameevent=gameevent,match_round=match_round).update(**validated_data)
        match.refresh_from_db()
        return validated_data
    else:
        return Matchscore.objects.create(**validated_data)
       
    
def validate(self, validated_data):
    gameevent = validated_data.get('gameevent')
    match_round =validated_data.get('match_round')
    if not match_round :
        raise serializers.ValidationError("Enter value more than 0")
    if match_round == 1:
        return validated_data
    round = range(1,match_round)
    match = Matchscore.objects.filter(gameevent=gameevent,match_round__in=round).values_list('match_round',flat=True)
    match = set(match)
    if match :
        return validated_data
    if len(match)== match_round-1:
        return validated_data
    else:
        raise serializers.ValidationError("Enter a valid match_round")

Here my model

class Matchscore(TimeStampedModel):
gameevent = models.ForeignKey(GameEvent, null=True, related_name='game_event',on_delete=models.DO_NOTHING)
match_round = models.IntegerField(null=True,blank=True)
team_a = models.ForeignKey(Team,null=True,related_name='team_one',on_delete=models.DO_NOTHING)
team_a_score = models.PositiveIntegerField(null=True,blank=True)
team_b = models.ForeignKey(Team,null=True,related_name='team_two',on_delete=models.DO_NOTHING)
team_b_score = models.PositiveIntegerField(null=True,blank=True)
team_won = models.ForeignKey(Team,null=True,related_name='team', on_delete=models.DO_NOTHING)


Sources

This article follows the attribution requirements of Stack Overflow and is licensed under CC BY-SA 3.0.

Source: Stack Overflow

Solution Source