Maison > base de données > tutoriel mysql > Pourquoi PDO insère-t-il 1 au lieu de 0 dans une colonne BIT(1) dans MySQL ?

Pourquoi PDO insère-t-il 1 au lieu de 0 dans une colonne BIT(1) dans MySQL ?

Patricia Arquette
Libérer: 2024-11-04 11:46:41
original
985 Les gens l'ont consulté

Why Does PDO Insert 1 Instead of 0 into a BIT(1) Column in MySQL?

Anomalie d'insertion d'instruction PDO avec un champ Bit(1)

Lors de l'insertion de valeurs dans un champ bit(1) à l'aide d'instructions préparées PDO, un un résultat inattendu se produit. Au lieu de la valeur 0 prévue, la base de données stocke 1 dans la table.

Cette anomalie est due à la nature binaire des colonnes BIT dans MySQL. Bien qu'ils soient classés comme numériques, ils sont traités comme des types binaires, entraînant des problèmes de compatibilité avec certaines bibliothèques clientes.

Solution utilisant TINYINT(1)

Pour éviter ce problème , envisagez plutôt de passer à une colonne TINYINT(1). Ce type de données alternatif offre des exigences de stockage similaires à BIT(1) tout en éliminant les problèmes de compatibilité avec PDO et d'autres bibliothèques client.

Utilisation de bindValue avec PDO::PARAM_INT

If changer le type de colonne n'est pas réalisable, une solution alternative implique d'utiliser bindValue avec l'indice de type PDO::PARAM_INT. Cette approche oblige PDO à traiter la valeur comme un entier, résolvant ainsi l'anomalie d'insertion.

Exemple de code

<code class="php">$pdo = new PDO("connection string etc");
$statement = $pdo->prepare('INSERT INTO `test` (SomeText,TestBool) VALUES (:someText,:testBool)');
$statement->bindValue(':someText', "TEST");
$statement->bindValue(':testBool', 0, PDO::PARAM_INT);
$statement->execute();</code>
Copier après la connexion

Notez que même si cette solution de contournement peut résoudre le problème d'insertion , il est toujours conseillé de passer à TINYINT(1) pour une compatibilité améliorée et des avantages potentiels en termes de performances.

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!

source:php.cn
Déclaration de ce site Web
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal