LastInsertId

Résolu
lachaux78 -  
LaChaux78 Messages postés 583 Date d'inscription   Statut Membre Dernière intervention   -
Bonjour Après utilisation de la méthode last_insert_id() de PDO je n'arrive pas a comprendre pourquoi je ne recupère pas le dernier idrep et donc ma deuxième requête ne s'insere pas, pouvez vous m'aider s'ils vous plait je vous remercie
	switch($_POST['haction']) {

		case 'new':
			$requete = "INSERT INTO cdc_repetitions (drepet) VALUES ('$drepet')";
			$typenr = "enregistré";
			$reqaj = $requete; 
			$resultat = executeQuery($requete,$bdd);
			
			$idrep = $bdd->lastInsertId();
			$presents = isset($_POST['presents']) ? $_POST['presents'] : NULL;
			
		if (is_array($presents)) {	
		    foreach($presents as $idpers) {
			
			$requete = "INSERT INTO cdc_assister (idpers,idrep,idloc) VALUES ('$idpers','$idrep','$idloc')";
			$typenr = "enregistré"; 
			$reqaj = $requete; 
			$resultat = executeQuery($requete,$bdd); 
		    }
		}
			$success = "<span class='success'>Les présences à la répétition - ".trim(stripslashes(" du " . dateFR("$drepet")))." - a été $typenr.</span>";
			break;
	}

Lorsque je fait $idrep = mysql_insert_id(); au lieu de $idrep = $bdd->lastInsertId(); la deuxième requète n'insere pas $idrep

16 réponses

PowerIslandHD Messages postés 571 Date d'inscription   Statut Membre Dernière intervention   172
 
jdoodle.sh: line 1: syntax error near unexpected token `$_POST['haction']'
jdoodle.sh: line 1: `switch($_POST['haction']) {'
0
jordane45 Messages postés 38486 Date d'inscription   Statut Modérateur Dernière intervention   4 752
 
Il nous faut le reste du code dr cette page.
0
LaChaux78 Messages postés 583 Date d'inscription   Statut Membre Dernière intervention   32
 
Bonjour
$action = 'new';                     
if($_GET['a']) { $a = $_GET['a']; }  
if(isset($_GET['idrep'])) { $idrep = $_GET['idrep']; }

switch($a) {
	case 'new': $action = 'new';  break; 
	default   : $action = 'new';  break;
}

if($_POST['submit']) {

	$idrep		= $_POST['idrep'];
    $drepet     = dw2m($_POST['drepet']);
	$idpers  	= $_POST['idpers'];
	$idloc  	= $_POST['idloc'];

	switch($_POST['haction']) {
		case 'new':
			$requete = "INSERT INTO cdc_repetitions (drepet) VALUES ('$drepet')";
			$typenr = "enregistré";
			$reqaj = $requete; 
			$resultat = executeQuery($requete,$bdd);
			
			$idrep = $bdd->lastInsertId();
			$presents = isset($_POST['presents']) ? $_POST['presents'] : NULL;
			
		if (is_array($presents)) {	
		    foreach($presents as $idpers) {
			
			$requete = "INSERT INTO cdc_assister (idpers,idrep,idloc) VALUES ('$idpers','$idrep','$idloc')";
			$typenr = "enregistré"; 
			$reqaj = $requete; 
			$resultat = executeQuery($requete,$bdd); 
		    }
		}
			$success = "<span class='success'>Les présences à la répétition - ".trim(stripslashes(" du " . dateFR("$drepet")))." - a été $typenr.</span>";
			break;
	}
}

switch($action) {
	case 'new':
		$title	= "Saisie des présences aux répétitions"; 
		$btsub	= "Enregistrer";
		$idrep	= "";
		$drepet	= "";
		$idpers	= "";
		$idloc	= 1;
		break;
}
0
jordane45 Messages postés 38486 Date d'inscription   Statut Modérateur Dernière intervention   4 752
 
Et le code de la fonction executeQuery ?
Tu ne sembles pas l'utiliser correctement si tu as conservé celle ue je t'avais donné...

De plus.., comme déjà dit.... Applique ceci :
https://forums.commentcamarche.net/forum/affich-37584947-php-gestion-des-erreurs-debogage-et-ecriture-du-code
0
LaChaux78 Messages postés 583 Date d'inscription   Statut Membre Dernière intervention   32
 
Bonjour
La fonction est dans mon fichier init.php que j'appelledans la page de mon script.
// Fonction qui sert à faire les requêtes SQL
function executeQuery($requete,$bdd) {
	$bdd = bdd();	
	//exécution de la requête
	try {
		$resultat = $bdd->prepare($requete);
		$resultat->execute();
	} catch(Exception $e) {
	// en cas d'erreur :
		echo " Erreur ! ".$e->getMessage();
		exit(0); // en cas d'erreur.. arrête le script !
	}
	return $resultat;
}
0
jordane45 Messages postés 38486 Date d'inscription   Statut Modérateur Dernière intervention   4 752
 
Tu as changé $datas par $bdd.... Pourquoi ?
0
LaChaux78 Messages postés 583 Date d'inscription   Statut Membre Dernière intervention   32
 
En fait après l'utilisation de la méthode lastinsertid() de PDO cela me retourne pas l'identifiant $idrep.
pPr contre j'ai bien en début de ma page la gestion des erreurs, cela me retourne quelques notice variable non défini mais rien qui corresponds à mon soucis.
0

Vous n’avez pas trouvé la réponse que vous recherchez ?

Posez votre question
jordane45 Messages postés 38486 Date d'inscription   Statut Modérateur Dernière intervention   4 752
 
Je te propose d'utiliser ces 3 fonctions.
Chacune servant à des types de requêtes spécifiques


/** Fonction qui sert à faire les requêtes SELECT SQL (UNIQUEMENT)
* @$requete string : requête SQL à effectuer
* @datas array contenant les éventuelles variables à passer à la requête
* return array : retourne un Array contenant le résultat du select
*/
function dbSelect($requete,$datas=NULL) {
 $bdd = bdd(); 
 //exécution de la requête
 try {
  $prep = $bdd->prepare($requete);
  $prep->execute($datas);
  $result = $prep->fetchAll();
 } catch(Exception $e) {
 // en cas d'erreur :
  echo " Erreur ! ".$e->getMessage();
  exit(0); // en cas d'erreur.. arrête le script !
 }
 return $result;
}

/** Fonction qui sert à faire les requêtes DELETE / UPDATE (UNIQUEMENT)
* @$requete string : requête SQL à effectuer
* @datas array contenant les éventuelles variables à passer à la requête
* return int : retourne le nombre de lignes impactées par la requête
*/
function dbExec($requete,$datas=NULL) {
 $bdd = bdd(); 
 //exécution de la requête
 try {
  $prep = $bdd->prepare($requete);
  $prep->execute($datas);
  $resultat = $prep->rowCount();
 } catch(Exception $e) {
 // en cas d'erreur :
  echo " Erreur ! ".$e->getMessage();
  exit(0); // en cas d'erreur.. arrête le script !
 }
 return $resultat;
}

/** Fonction qui sert à faire les requêtes INSERT (UNIQUEMENT)
* @$requete string : requête SQL à effectuer
* @datas array contenant les éventuelles variables à passer à la requête
* return int : retourne le "LastId" généré par l'insert
*/
function dbInsert($requete,$datas=NULL) {
 $bdd = bdd(); 
 //exécution de la requête
 try {
  $prep = $bdd->prepare($requete);
  $prep->execute($datas);
  $resultat = $bdd->lastInsertId();
 } catch(Exception $e) {
 // en cas d'erreur :
  echo " Erreur ! ".$e->getMessage();
  exit(0); // en cas d'erreur.. arrête le script !
 }
 return $resultat;
}


ce qui, pour ton code actuel, se traduirait par :
case 'new':
 $requete = "INSERT INTO cdc_repetitions (drepet) VALUES (:drepet)";
 $datas = array(':drepet'=>$drepet);
 $idrep = dbInsert($requete,$datas);
 $typenr = "enregistré";
 $reqaj = $requete; 
    
 $presents = isset($_POST['presents']) ? $_POST['presents'] : NULL;


0
LaChaux78 Messages postés 583 Date d'inscription   Statut Membre Dernière intervention   32
 
J'ai une erreur qui correspond à la fonction dbSelect
Fatal error: Call to a member function fetchAll() on boolean in /home/cliquede/admin/libs/init.php on line 52
0
jordane45 Messages postés 38486 Date d'inscription   Statut Modérateur Dernière intervention   4 752
 
Petite erreur :
$result = $res->fetchAll();


A remplacer par :
$result = $prep->fetchAll();



J'édite mon code précédent pour l'y corriger également.
0
LaChaux78 Messages postés 583 Date d'inscription   Statut Membre Dernière intervention   32
 
Maintenant que j'ai les fonctions pour faire mes requêtes tu peux me donner un exemple d'une requête SELECT s'il te plait.

0
jordane45 Messages postés 38486 Date d'inscription   Statut Modérateur Dernière intervention   4 752
 
$sql = "SELECT n.numero 
            FROM cdc_numerotation N left join cdc_interpreter I on N.idnum=I.idnum
WHERE I.idnum is null"; 
$datas = NULL; //pas de variable à passer pour cette requête la...
$array_result = dbSelect($sql,$datas);

//on affiche le résultat de la requete
print_r($array_result);

//ou via une boucle par exemple :
foreach ($array_result as $R){
  echo $R['numero'];
}
0
LaChaux78 Messages postés 583 Date d'inscription   Statut Membre Dernière intervention   32
 
J'ai cette erreur
Fatal error: Call to a member function fetch() on array in

avec cette requète

$requete = "SELECT * FROM $cfg";
$datas = NULL;
$config = dbSelect($requete,$datas);
while ($donnees = $config->fetch()) { ${$donnees->clef} = $donnees->valeur; }
0
jordane45 Messages postés 38486 Date d'inscription   Statut Modérateur Dernière intervention   4 752 > LaChaux78 Messages postés 583 Date d'inscription   Statut Membre Dernière intervention  
 
Normal ... vu que tu n'as pas regardé le code que je t'ai donné
remplace ton while par :
//ou via une boucle par exemple :
foreach ($configas as $donnees){
  ${$donnees->clef} = $donnees->valeur
}


PS: ... au passage .....j'aimerai bien qu'un jour... tu te mettes enfin à utiliser la COLORATION SYNTAXIQUE lorsque tu postes du code sur le forum... pour ça... rien de plus simple... il suffit de préciser le LANGAGE dans les balises de code.
Explications disponibles ici : https://codes-sources.commentcamarche.net/faq/10686-le-nouveau-codes-sources-comment-ca-marche#balises-code
0
LaChaux78 Messages postés 583 Date d'inscription   Statut Membre Dernière intervention   32
 
Bonjour,
Maintenant j'ai un autre soucis sur une requête SELECT avec la fonction rowCount.
Cela me permet de rechercher le timestamp de la dernière sauvegarde de ma BDD.
Fatal error: Call to a member function rowCount() on array in......

$lastsave   = 0;
$nbsave     = 0;
$lastsql    = '';

$requete = "SELECT UNIX_TIMESTAMP(save) AS lsave,fichier FROM cdc_saves ORDER BY save DESC;";
$resultat = dbSelect($requete,$datas);
$nbsave = $resultat->rowCount();
	if($nbsave != 0) {
		$donnees = $resultat->fetch();
		$lastsave = $donnees->lsave;
		$lastsql  = $donnees->fichier;
	}
0
jordane45 Messages postés 38486 Date d'inscription   Statut Modérateur Dernière intervention   4 752
 
A la place de rowcount.. fais juste in count($resultat);
0
LaChaux78 Messages postés 583 Date d'inscription   Statut Membre Dernière intervention   32
 
merci encore une erreur avec fech. j'ai essayé fechAll et même fetchColumn
Fatal error: Call to a member function fetchAll() on array in 
0
jordane45 Messages postés 38486 Date d'inscription   Statut Modérateur Dernière intervention   4 752
 
A quelle ligne de code ???
Si c'est après la fonction dbSelect.... Cest normal... Tu as déjà un array !
0
LaChaux78 Messages postés 583 Date d'inscription   Statut Membre Dernière intervention   32
 
oui c'est après la fonction dbselec...
$requete = "SELECT UNIX_TIMESTAMP(save) AS lsave,fichier FROM cdc_saves ORDER BY save DESC;";
$resultat = dbSelect($requete,$datas);
$nbsave = count($resultat);
	if($nbsave != 0) {
		$donnees = $resultat->fetch();
		$lastsave = $donnees->lsave;
		$lastsql  = $donnees->fichier;
	}
0
jordane45 Messages postés 38486 Date d'inscription   Statut Modérateur Dernière intervention   4 752
 
Fais donc un print_r($resultat); et regarde ce que ca donne... Tu devrais comprendre...
0
LaChaux78 Messages postés 583 Date d'inscription   Statut Membre Dernière intervention   32
 
Cela me renvoie donc toutes mes sauvegardes sous forme d'objet?
donc j'ai fait un foerach...
$requete = "SELECT UNIX_TIMESTAMP(save) AS lsave,fichier FROM cdc_saves ORDER BY save DESC;";
$resultat = dbSelect($requete,$datas);
$nbsave = count($resultat);
	if($nbsave != 0) {
		foreach ($resultat as $donnees);
		$lastsave = $donnees->lsave;
		$lastsql  = $donnees->fichier;
	}
0
jordane45 Messages postés 38486 Date d'inscription   Statut Modérateur Dernière intervention   4 752
 
Et ben voila..
0
LaChaux78 Messages postés 583 Date d'inscription   Statut Membre Dernière intervention   32
 
Les erreurs se suivent et ne se ressemble pas....
J'ai une erreurs ou plutôt 4 notices (les mêmes à la même lignes) toujours dans le fichier init.php
Que signifie cette erreur en fait j'essaie de regarder depuis un moment mais rien de bien précis.
Merci
Notice: Undefined offset: 2 in /home/cliquede/admin/libs/init.php on line 157
0
jordane45 Messages postés 38486 Date d'inscription   Statut Modérateur Dernière intervention   4 752
 
0
LaChaux78 Messages postés 583 Date d'inscription   Statut Membre Dernière intervention   32
 
Bonjour,
Quelque chose que je ne comprends pas c'est à propos des boucles while.
Du coup j'ai cette erreur chaque fois que j'ai une boucle while. Je la remplace par foreach pourquoi??
Merci
while ($donnees = $resultat->fetch()) {

Fatal error: Call to a member function fetch() on array in
0
jordane45 Messages postés 38486 Date d'inscription   Statut Modérateur Dernière intervention   4 752
 
Pourquoi ? ... par ce que dans la fonction dbSelect ... tu as la ligne de code
$result = $prep->fetchAll();

Le résultat que tu obtiens de la fonction dbSelect ... est DEJA un (comme indiqué dans le message d'erreur.... )... ARRAY.
Tu n'as donc pas besoin (et d'ailleurs, comme tu peux le voir, ça ne marche pas....) de faire un FETCH.... il est déjà fait !

Si vraiement tu souhaites pouvoir faire tes fetch en dehors de la fonction.... dans ce cas il faut, soit modificer la fonction pour retirer la ligne .. soit en faire une nouvelle qui te permette de faire tes fetch en dehors.
0
LaChaux78 Messages postés 583 Date d'inscription   Statut Membre Dernière intervention   32
 
J'ai compris merci.
A propos de mon soucis initial pour mes requètes INSERT en fait j'ai uniquement 1 seule entrée qui est pris en compte c'est à dire si je coche plusieurs membres l'INSERT de l'idrep se fera qu'une fois.
Voici l'exemple.
table cdc_repetitions
idrep drepet
137 28/02/2018

table cdc_assister
idpers idrep idloc
25 137 2
38 0 2
117 0 2
if($_POST['submit']) {

	$idrep		= $_POST['idrep'];
    $drepet     = dw2m($_POST['drepet']);
	$idpers  	= $_POST['idpers'];
	$idloc  	= $_POST['idloc'];

	switch($_POST['haction']) {
		case 'new':
    	$requete = "INSERT INTO cdc_repetitions (drepet) VALUES (:drepet)";
	$datas = array('drepet'=>$drepet);
	$idrep = dbInsert($requete,$datas);
	$typenr = "enregistré";
	$reqaj = $requete;
			

			$presents = isset($_POST['presents']) ? $_POST['presents'] : NULL;
			
		if (is_array($presents)) {	
		    foreach($presents as $idpers) {
			
			$requete = "INSERT INTO cdc_assister (idpers,idrep,idloc) VALUES (:idpers,:idrep,:idloc)";
	$datas = array('idpers'=>$idpers, 'idrep'=>$idrep, 'idloc'=>$idloc);
	$idrep = dbInsert($requete,$datas);
	$typenr = "enregistré";
	$reqaj = $requete; 
		    }
		}
			$success = "<span class='success'>Les présences à la répétition - ".trim(stripslashes(" du " . dateFR("$drepet")))." - a été $typenr.</span>";
			break;
	}
}
0
jordane45 Messages postés 38486 Date d'inscription   Statut Modérateur Dernière intervention   4 752
 
Je ne comprend pas trop ton explication......

A propos de mon soucis initial pour mes requètes INSERT en fait j'ai uniquement 1 seule entrée qui est pris en compte c'est à dire si je coche plusieurs membres l'INSERT de l'idrep se fera qu'une foi

ce que tu décris... c'est le comportement VOULU ... ou celui que tu constates actuellement ??


Peux tu faire (en début de ton code )
echo "<pre>";
print_r($_POST);
echo "</pre>";



une fois avec un seul user
une fois avec plusieurs

et tu nous colles ça entre balises de code sur la discussion....
0
LaChaux78 Messages postés 583 Date d'inscription   Statut Membre Dernière intervention   32
 
En fait l'INSERT de l'idrep est vide dans la table cdc_repetitions il y a bien l'enregistrement
Array
(
    [drepet] => 28/02/2018
    [idloc] => 2
    [haction] => new
    [idrep] => 
    [presents] => Array
        (
            [0] => 110
            [1] => 117
        )

    [submit] => Enregistrer
)
0
LaChaux78 Messages postés 583 Date d'inscription   Statut Membre Dernière intervention   32
 
Excuse moi j'ai résolu ce soucis.
0
jordane45 Messages postés 38486 Date d'inscription   Statut Modérateur Dernière intervention   4 752
 
Donc... si le problème est réglé ... merci de mettre le sujet en RESOLU (via l'icone de roue cranté en haut de la discussion )
0
LaChaux78 Messages postés 583 Date d'inscription   Statut Membre Dernière intervention   32
 
Je te remercie.
0