Avatar billede hoejgaard Juniormester
25. november 2008 - 21:52 Der er 4 kommentarer og
1 løsning

problem med while løkke

Jeg har følgende hvor der ikke bliver slettet det der skal.
Det er som om while løkken ikke bliver gennemløbet flere gange, hvis der er mere end en række der opfylder forespørgslen: where brugernavn = '$userid' AND id = '$row[id]'  ??
Hvad kan der være fejl ??

foreach ($del_me as $row[id])
{
$query = mysql_query("SELECT billede,billede_lille,video FROM bilag where brugernavn = '$userid' AND id = '$row[id]'");
while ($ri = mysql_fetch_array($query)) {
              $ri = mysql_fetch_array($query); 
              $sti = "/billede_bilag/";
              $sti1 = "/billede_bilag_lille/";
              $sti2 = "/video_bilag/";
              $dist = $_SERVER["DOCUMENT_ROOT"] ."$sti"."$ri[billede]";
              $dist1 = $_SERVER["DOCUMENT_ROOT"] ."$sti1"."$ri[billede_lille]";
              $dist2 = $_SERVER["DOCUMENT_ROOT"] ."$sti2"."$ri[video]";
              if(file_exists($dist))
              unlink($dist);
              if(file_exists($dist1))
              unlink($dist1);
              if(file_exists($dist2))
              unlink($dist2);  }
       
mysql_query("delete from bilag where brugernavn = '$userid' AND id = '$row[id]'") or die(mysql_error());

}
Avatar billede erikjacobsen Ekspert
25. november 2008 - 21:55 #1
Du kan roligt slette nummer 2 af
      $ri = mysql_fetch_array($query);
Avatar billede hoejgaard Juniormester
25. november 2008 - 22:26 #2
erik
ja det er vel den der ødelægger det... vil prøve at slette den og se om det viker.
Avatar billede hoejgaard Juniormester
25. november 2008 - 23:07 #3
ja det var der fejlen var.. Mange tak for hjælpen og dit skarpe blik :-)
Vil du stadig ikke ha points Erik ??
Avatar billede erikjacobsen Ekspert
25. november 2008 - 23:16 #4
Nej tak.

Det der sker i din oprindelige kode, er at du springer hver anden række over. Man skal lave een mysql_fetch_array pr række. Der er udbredt tradition for at gøre det i while-løkken.
Avatar billede hoejgaard Juniormester
25. november 2008 - 23:30 #5
okay tak for det.
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Vi tilbyder markedets bedste kurser inden for webudvikling

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester