L'insertion de lignes en double dans une table peut entraîner un comportement inattendu avec le mécanisme d'incrémentation automatique de MySQL. Dans MySQL 5.1.49, l'ID d'auto-incrémentation continue d'augmenter même si une instruction INSERT IGNORE est utilisée. Cela peut entraîner des lacunes indésirables dans la séquence d'identification.
Pour résoudre ce problème, vous pouvez utiliser les stratégies suivantes :
INSERT INTO tablename (tag) SELECT $tag FROM tablename WHERE NOT EXISTS( SELECT tag FROM tablename WHERE tag = $tag ) LIMIT 1
Cette instruction vérifie d'abord si la balise existe déjà dans la table. Si ce n'est pas le cas, la ligne est insérée sans déclencher le mécanisme d'auto-incrémentation. La sous-requête garantit que l'insertion n'a lieu qu'une seule fois.
Il est important de noter que ces solutions peuvent ne pas convenir à tous les scénarios. Si les performances sont un problème, il peut être nécessaire d'évaluer d'autres options, comme utiliser une table séparée pour stocker des valeurs uniques et les référencer dans votre table principale.
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!