LastInsertId
Résolu
lachaux78
-
LaChaux78 Messages postés 583 Date d'inscription Statut Membre Dernière intervention -
LaChaux78 Messages postés 583 Date d'inscription Statut Membre Dernière intervention -
16 réponses
jdoodle.sh: line 1: syntax error near unexpected token `$_POST['haction']'
jdoodle.sh: line 1: `switch($_POST['haction']) {'
jdoodle.sh: line 1: `switch($_POST['haction']) {'
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.
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; }
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
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
Bonjour
La fonction est dans mon fichier init.php que j'appelledans la page de mon script.
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; }
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.
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.
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
Je te propose d'utiliser ces 3 fonctions.
Chacune servant à des types de requêtes spécifiques
ce qui, pour ton code actuel, se traduirait par :
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;
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
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.
$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']; }
Normal ... vu que tu n'as pas regardé le code que je t'ai donné
remplace ton while par :
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
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
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.
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; }
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
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; }
Cela me renvoie donc toutes mes sauvegardes sous forme d'objet?
donc j'ai fait un foerach...
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; }
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
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
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
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
Pourquoi ? ... par ce que dans la fonction dbSelect ... tu as la ligne de code
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.
$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.
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
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; } }
Je ne comprend pas trop ton explication......
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 )
une fois avec un seul user
une fois avec plusieurs
et tu nous colles ça entre balises de code sur la discussion....
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....
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 )