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 :

Insertion en base [PDO]


Sujet :

PHP & Base de données

Vue hybride

kanabzh29 Insertion en base 18/08/2008, 16h06
sabotage Tu inseres NULL pour l'id ? 18/08/2008, 16h10
kanabzh29 L'id est en auto... 18/08/2008, 16h15
sabotage Les requetes d'insertion se... 18/08/2008, 16h23
kanabzh29 J'ai modifié mon code avec... 18/08/2008, 16h40
Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    288
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 288
    Par défaut Insertion en base
    Bonjour,

    J'ai un problème avec l'insertion en base...tout simplement cela ne veut pas insérer, voila mon code :

    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
     
     
    if(file_exists("_xml/".$filename.".xml")){
     
    		## Insertion en base d'une ligne contenant la date du jour sur 8 digit : 00/00/00 ########
    		$current_date_base = date('dmy',mktime(0,0,0,date('m'),date('d'),date('y')));
     
    		$count = $dbh->query("SELECT * FROM synt_inc WHERE date = '$current_date_base'");
    		$result_count = $count->rowCount();
    		if($result_count == 0){
    			$sql = mysql_query("INSERT INTO synt_inc(id, date, pend_cust, pend_vend, vide, wip, pro_solu) VALUES (NULL, $current_date_base, '0', '0', '0', '0', '0')");
    			$result = $dbh->query($sql);
    		}else{
    		}
    	}
    Pourtant si à la place des lignes d'insertion, je mets un simple bonjour pour voir si il rentre dans la condition, il l'affiche, donc il prends bien en compte les PDO

  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
    Tu inseres NULL pour l'id ?
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Membre éclairé
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    288
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 288
    Par défaut
    L'id est en auto incrémentation, c'est la clé.

  4. #4
    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
    Les requetes d'insertion se font avec exec je ne sais pas ce que ca donne avec query.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  5. #5
    Membre éclairé
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    288
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 288
    Par défaut
    J'ai modifié mon code avec exec :

    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
     
     
    if(file_exists("_xml/".$filename.".xml")){
    		echo 'bonjour';
    		## Insertion en base d'une ligne contenant la date du jour sur 8 digit : 00/00/00 ########
    		$current_date_base = date('dmy',mktime(0,0,0,date('m'),date('d'),date('y')));
     
    		$count = $dbh->exec("SELECT * FROM synt_inc WHERE date = '$current_date_base'");
    		$result_count = $count->rowCount();
    		if($result_count == 0){
    			echo 'zero insertion';
    			$sql = "INSERT INTO synt_inc(date, pend_cust, pend_vend, vide, wip, pro_solu) VALUES (NULL, '$current_date_base', '0', '0', '0', '0', '0')";
    			$dbh->exec($sql);
    		}else{
    		}
    	}
    Il marque bien 'bonjour' mais pas 'zero insertion' et n'insere pas la ligne...grrr je comprends pas tout

  6. #6
    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
    ah petit chenapan, tu ne rentrais pas dans la boucle en fait.

    rowcount ne doit pas servir pour compter un SELECT.

    Voir la doc pour la bonne méthode de comptage :
    http://fr.php.net/manual/en/pdostatement.rowcount.php
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 9
    Dernier message: 13/10/2005, 18h24
  2. Réponses: 8
    Dernier message: 11/05/2005, 14h48
  3. Insertion multiple à base de sous requête SELECT
    Par drinkmilk dans le forum Langage SQL
    Réponses: 8
    Dernier message: 14/04/2005, 16h34
  4. [ADO.NET] Problème avec Insert dans base de données
    Par mpascolo dans le forum Accès aux données
    Réponses: 9
    Dernier message: 24/01/2005, 09h36
  5. PB date lors d'une insertion en Base.
    Par NATHW dans le forum Langage SQL
    Réponses: 4
    Dernier message: 09/09/2004, 17h53

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