Aide en php
Zie882
-
Zie882 -
Zie882 -
Bonjour,
Bonjour, svp je fais actuellement une application de parrainage d'étudiant première année - deuxième année dans laquelle j'ai attribut des id aléatoire de parrain à chaque filleul et je n'arrive pas à faire de sort que tout les parrains de deuxième année ait au moins un filleul en première année. Quelqu'un peut il m'aider svp ?
Bonjour, svp je fais actuellement une application de parrainage d'étudiant première année - deuxième année dans laquelle j'ai attribut des id aléatoire de parrain à chaque filleul et je n'arrive pas à faire de sort que tout les parrains de deuxième année ait au moins un filleul en première année. Quelqu'un peut il m'aider svp ?
Configuration: Android / Chrome 75.0.3770.101
3 réponses
-
Bonjour
Tu places la liste des id de parain dans un array
Idem avec la liste des premières années
Ensuite, tu boucle sur l'array des parains et pour chacun, tu tires au hasard un id de première (que tu enleves ensuite de son array)
-
-
-
-
-
<?php if (isset($_POST['inscrire_p'])) { //verification si les données parrains saisies if (!empty($_POST['nom_p']) AND !empty($_POST['prenom_p']) AND ! empty($_POST['classe_p']) AND !empty($_POST['genre_p']) AND !empty($_POST['numero_p'])) { $nom_p = htmlspecialchars($_POST['nom_p']); $prenom_p = htmlspecialchars($_POST['prenom_p']); $classe_p = htmlspecialchars($_POST['classe_p']); $genre_p = htmlspecialchars($_POST['genre_p']); $numero_p = $_POST['numero_p']; $date = date("d-m-Y H:i:s"); $insertion = $db->prepare(" INSERT INTO parrain(id_p, nom_p, prenom_p, classe_p, genre_p, numero_p, creation_le) VALUES('', ?, ?, ?, ?, ?, ?)"); $insertion->execute(array($nom_p, $prenom_p, $classe_p, $genre_p, $numero_p, $date)); $flashalertep = '<div class="alert alert-success"> Inscription terminée, félicitation parrain '.$nom_p.' '.$prenom_p.' </div>'; }else{ $flashalertep = '<div class="alert alert-danger"> Erreur de remplissage des champs !!! Tous les champs sont obligatoires </div>'; } } if (isset($_POST['inscrire_f'])) { //verification si les données du filleuls saisies if (!empty($_POST['nom_f']) AND !empty($_POST['prenom_f']) AND ! empty($_POST['classe_f']) AND !empty($_POST['genre_f']) AND !empty($_POST['numero_f'])) { $nom_f = htmlspecialchars($_POST['nom_f']); $prenom_f = htmlspecialchars($_POST['prenom_f']); $classe_f = htmlspecialchars($_POST['classe_f']); $genre_f = htmlspecialchars($_POST['genre_f']); $numero_f = $_POST['numero_f']; // si oui insertion des données
$key = rand(1, 1000); $requete = $db->prepare(" SELECT * FROM parrain WHERE id_p = ? "); $requete->execute(array($key)); $verifier = 1; while ($verifier == 1) { if ($resultats = $requete->fetch() ) { $verifier = 0; }else{ $key = rand(1, 1000); $requete = $db->prepare(" SELECT * FROM parrain WHERE id_p = ? "); $requete->execute(array($key)); } } $insertion = $db->prepare(" INSERT INTO filleul(id_f, nom_f, prenom_f, classe_f, numero_f, genre_f, cle) VALUES('', ?, ?, ?, ?, ?, ?)"); $insertion->execute(array($nom_f, $prenom_f, $classe_f, $numero_f, $genre_f, $key)); $flashalertef = '<div class="alert alert-success"> Inscription terminée, félicitation filleul '.$nom_f.' '.$prenom_f.' </div>'; }else{ $flashalertef = '<div class="alert alert-danger"> Erreur de remplissage des champs !!! Tous les champs sont obligatoires </div>'; } } ?>
-
-
On s'est mal compris...
Quand je parlais de voir ton code... c'était "APRES" avoir pris en compte la "logique" que je t'avais donné....
Donc, pour que tu comprennes la "logique", tu peux essayer ceci :
<?php $array_parains = array(1,2,3,5,9,10); $array_filleuls = array(1,6,65,33,124,564,7789,213,545,88); $result = array(); //pour chaque parain on associe un filleul foreach($array_parains as $P){ //on prend un filleul au hasard if(!empty($array_filleuls)){ $rnd_key = array_rand($array_filleuls,1); $rand_filleul = $array_filleuls[$rnd_key]; $result[]=array('id_parain'=>$P,'id_filleul'=>$rand_filleul); unset($array_filleuls[$rnd_key]); } } echo "<pre>"; print_r($result); echo "</pre>"; echo "<br> Mais il reste des filleuls..."; echo "<pre>"; print_r($array_filleuls); echo "</pre>"; //maintenant.. si il reste des filleuls à assigner... if(!empty($array_filleuls)){ foreach($array_filleuls as $F){ $rnd_key = array_rand($array_parains,1); $result[]=array('id_parain'=>$array_parains[$rnd_key],'id_filleul'=>$F); } } echo "<hr><br>Le résultat final "; echo "<pre>"; print_r($result); echo "</pre>";
A toi de le retranscrire avec les requêtes en Base de données ...
PS: Vu que tu fais du PDO, je t'invite vivement à lire et à appliquer ceci :
https://forums.commentcamarche.net/forum/affich-37584941-php-pdo-gerer-les-erreurs
Et au passage.. ceci également :
https://forums.commentcamarche.net/forum/affich-37584947-php-gestion-des-erreurs-debogage-et-ecriture-du-code
-
Aok je crois que je comprends maintenant ce dont tu parlais. Donc j'utiliserai votre logique et voit ce que ça donne ensuite