Maison  >  Article  >  développement back-end  >  Comment gérer le problème de conversion de clé primaire de chaîne personnalisée dans Laravel 5.2

Comment gérer le problème de conversion de clé primaire de chaîne personnalisée dans Laravel 5.2

Linda Hamilton
Linda Hamiltonoriginal
2024-10-19 16:53:30942parcourir

How to Handle Custom String Primary Key Conversion Issue in Laravel 5.2

Laravel 5.2 - Clé primaire personnalisée sous forme de chaîne : résolution de la conversion '0'

Utilisation d'une chaîne comme clé primaire pour une table éloquente peut entraîner des problèmes de conversion inattendus. Cet article aborde le problème de la rencontre de la valeur « 0 » lors de la récupération de la clé primaire.

Énoncé du problème :

Lors de la tentative d'utilisation du courrier électronique comme clé primaire, Eloquent renverrait la clé primaire sous la forme « 0 » lors de l'interrogation de la table en utilisant « où » avec la clé primaire comme argument. Cela a affecté la récupération d'autres attributs du modèle.

Solution :

Pour résoudre ce problème de conversion, deux propriétés doivent être configurées dans le modèle Eloquent :

  1. incrémentation : Définissez ceci sur « false » pour indiquer que la clé primaire ne s'incrémente pas automatiquement (comme c'est généralement le cas pour les clés de chaîne).
  2. keyType (Laravel 6.0 uniquement) : Définissez ceci sur « string » pour spécifier explicitement que la clé primaire est une chaîne.

Voici le modèle Eloquent mis à jour :

<code class="php">class UserVerification extends Model
{
    protected $primaryKey = 'verification_token';
    protected $incrementing = false;
    protected $keyType = 'string';
    // Other model definitions...
}</code>

En configurant ces propriétés, Laravel gérera désormais correctement la clé primaire de la chaîne et évitera de la convertir en entier, résolvant ainsi le problème de conversion « 0 ».

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn