IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

PHP & Base de données Discussion :

mysqli ok en SELECT NOK en INSERT


Sujet :

PHP & Base de données

  1. #1
    Membre confirmé

    Homme Profil pro
    Développeur Web
    Inscrit en
    Janvier 2014
    Messages
    153
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Janvier 2014
    Messages : 153
    Par défaut mysqli ok en SELECT NOK en INSERT
    Bonjour,

    Je butte depuis hier soir sur un problème avec Mysqli.

    Je souhaite inseré dans une base le compte d'un nouvel utilisateur comme ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $query = $mysqli->query('INSERT INTO compte (creationdate, pseudo, password, photo, mail) VALUES (NOW(), "seee" , "$2y$10$p6SXp/P/3fn6v29wjFpgDeOcuJEhO5FxpW/tEvnqc/z3o00kWi1bO", "images_utilisateurs/PP.jpg", "ttt@ttt.com")');
    $query renvois TRUE mais aucune donnée n'est insérée.
    Néanmoins :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    $query = $mysqli->query('SELECT mail FROM compte');
    while ($result = $query->fetch_array()) {
     
        var_dump($result['mail']);
    }
    liste correctement les mail de tous les utilisateurs.


    Voici le code de configuration issus de mon fichier mysql.php et construis sur l'exemple de la doc de php.net:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    $mysqli = mysqli_init();
    if (!$mysqli) {
        die('mysqli_init failed');
    }
     
     
    if (!$mysqli->options(MYSQLI_INIT_COMMAND, 'SET AUTOCOMMIT = 0')) {
        die('Setting MYSQLI_INIT_COMMAND failed');
    }
     
    if (!$mysqli->options(MYSQLI_OPT_CONNECT_TIMEOUT, 5)) {
        die('Setting MYSQLI_OPT_CONNECT_TIMEOUT failed');
    }
     
    if (!$mysqli->real_connect('localhost', 'root', 'root', 'basetest')) {
        die('Connect Error (' . mysqli_connect_errno() . ') '
                . mysqli_connect_error());
    }
    Ai-je stupidement oublié quelque chose dans mon INSERT?

    Merci

  2. #2
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    Pourquoi le ?
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Par défaut
    Au passage, tu peux vérifier le nombre de lignes insérées par ta requête en utilisant affected_rows :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $query = $mysqli->query('INSERT INTO compte (creationdate, pseudo, password, photo, mail) VALUES (NOW(), "seee" , "$2y$10$p6SXp/P/3fn6v29wjFpgDeOcuJEhO5FxpW/tEvnqc/z3o00kWi1bO", "images_utilisateurs/PP.jpg", "ttt@ttt.com")');
    var_dump($mysqli->affected_rows);
    Modératrice PHP
    Aucun navigateur ne propose d'extension boule-de-cristal : postez votre code et vos messages d'erreurs. (Rappel : "ça ne marche pas" n'est pas un message d'erreur)
    Cherchez un peu avant poser votre question : Cours et Tutoriels PHP - FAQ PHP - PDO une soupe et au lit !.

    Affichez votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur) et [C=php][/C]

  4. #4
    Membre confirmé

    Homme Profil pro
    Développeur Web
    Inscrit en
    Janvier 2014
    Messages
    153
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Janvier 2014
    Messages : 153
    Par défaut
    Citation Envoyé par sabotage Voir le message
    Pourquoi le ?
    Pour les try catch... Que j'ai oublié dans mon super code (La tete dans le guidon => )

    Voici la doc là dessus: http://php.net/manual/fr/mysqli.commit.php

    Je test ce soir et je résous le sujet si c'est bon

Discussions similaires

  1. Récuperation du max avec 2 select pour un insert
    Par Kiroukool dans le forum SQL
    Réponses: 5
    Dernier message: 02/08/2007, 09h31
  2. SELECT dans un INSERT
    Par todier dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 17/04/2007, 15h44
  3. [MySQL] Select double et insertion dans fichier
    Par Anakior dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 02/01/2006, 15h11
  4. [SQL] SELECT dans un INSERT
    Par macben dans le forum Oracle
    Réponses: 3
    Dernier message: 28/12/2005, 09h40
  5. [ASE]probleme memoire: select dans une insert
    Par SegmentationFault dans le forum Sybase
    Réponses: 2
    Dernier message: 16/08/2005, 12h20

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo