Dans le framework Laravel, vérifier le caractère unique des données d'entrée est une exigence courante. Par exemple, vérifiez l'e-mail ou le numéro de téléphone portable de l'utilisateur pour vous assurer qu'il ne sera pas enregistré à plusieurs reprises.
Laravel fournit une règle de vérification très pratique - unique. Lors de la soumission du formulaire, il vous suffit d'ajouter unique:table,column aux règles, par exemple :
'username' => 'required|unique:users,username|max:255', 'email' => 'required|unique:users,email|max:255|email',
Dans le code ci-dessus, la règle unique précise la table de vérification d'unicité des utilisateurs et le champ nom d'utilisateur ou email, ce qui garantira que aucun autre utilisateur ne l'utilise. Même nom d'utilisateur ou même adresse e-mail.
Cependant, dans les applications pratiques, les règles uniques ne répondent pas pleinement à nos besoins. Par exemple, lorsque nous mettons à jour une donnée, la règle de vérification d'unicité d'origine peut signaler une erreur car la valeur que nous mettons à jour existe déjà dans la base de données.
Pour résoudre ce problème, Laravel fournit un paramètre supplémentaire : exclure. Par exemple :
'username' => 'required|unique:users,username,' . $userId . ',id|max:255',
Dans le code ci-dessus, $userId représente l'ID utilisateur actuel à mettre à jour. Nous disons à Laravel d'exclure l'utilisateur actuel lors de la vérification de l'unicité en utilisant le paramètre d'exclusion dans la règle unique.
En plus du paramètre d'exclusion, Laravel fournit également le paramètre other_columns pour spécifier les conditions des autres colonnes. Par exemple :
'username' => Rule::unique('users') ->where(function ($query) use ($other_column_value) { return $query->where('other_column', $other_column_value); }) ->ignore($userId),
Dans le code ci-dessus, nous utilisons la classe Rule et la méthode Where pour définir des conditions pour d'autres colonnes, garantissant que la vérification de l'unicité ne sera limitée que par les conditions spécifiées. La méthode ignore est également utilisée pour exclure l’utilisateur actuel.
Pour résumer, vous devez faire attention aux problèmes suivants lors de la vérification de l'unicité dans Laravel :
En utilisant les techniques ci-dessus, nous pouvons vérifier le caractère unique des données de manière plus flexible et garantir l'intégrité et l'exactitude des données.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!