Avatar billede delphiuser Mester
30. september 2014 - 18:03 Der er 4 kommentarer og
1 løsning

Fjern indhold på bestemt dato

Hej eksperter

Jeg har et lille spørgsmål og problem som jeg ikke lige ved hvordan jeg skal løse.
Jeg har et lille service system jeg er ved at bygge hvor jeg kan skrive nogle forskellige service beskeder til mine brugere. Men det skal være sådan at når beskeden har ligget i max 7 dage skal den forsvinde fra listen som brugerne kan se.

Nu har jeg prøvet noget forskelligt. Men kan ikke få det til at virke. er der en mulighed for at i kan hjælpe mig.

den som hedder $s_dates = $row['s_dates']; det er den dato hvor at indholdet skal forsvinde. Men som sagt jeg kan simpelthen ikke gennemskue hvordan jeg gør det.

mit script ser sådan her ud.

<?php
    $sql = "select * from service";
    $hent = mysql_query($sql);
    if(mysql_num_rows($hent) > 0) {
        while($row = mysql_fetch_assoc($hent)) {
            $s_type = $row['s_type'];
            $s_title = $row['s_title'];
            $s_date = $row['s_date'];
            $s_id = $row['s_id'];
            $s_dates = $row['s_dates'];
            if($s_type == 'vigtigt') {
                $flag = '<img src="img/red.ico">';
            }
            if($s_type == 'advarsel') {
                $flag = '<img src="img/yellow.ico">';
            }
            if($s_type == 'normal') {
                $flag = '<img src="img/green.ico">';
            }
            echo $flag.' <a href="#">'.$s_title.'</a><br>';
        }
    } else {
        echo 'Der findes ikke nogen service beskeder';
    }
    ?>

Jeg håber inderligt i kan hjælpe evt. ved at fortælle og vise mig hvor jeg skal sætte noget ind i min kode...

på forhånd tak for hjælpen

delphiuser
Avatar billede nemlig Professor
30. september 2014 - 22:29 #1
Hejsa.
Jeg ved ikke, om jeg forstået det 100%.
Men hvis du har en række poster i din tabel, og du kun ønsker at vise de poster, hvor `s_dates` ikke er ældre end 7 dage, så vil jeg forslå, at du laver begrænsningen i din sql-forespørgsel.

Noget ala:

$sql = "select * from service WHERE `s_dates` DATE_ADD(now(), INTERVAL -7 DAY) ";
Avatar billede repox Seniormester
01. oktober 2014 - 09:25 #2
Måske noget ala dette ville løse det?

<?php
    $sql = "SELECT * FROM service WHERE s_dates > NOW() - INTERVAL 7 DAY";
    $hent = mysql_query($sql);

    $icons = array('vigtig' => 'red', 'advarsel' => 'yellow', 'normal' => 'green');

    if(mysql_num_rows($hent) > 0)
    {
        while($row = mysql_fetch_assoc($hent))
        {           
            echo "<img src=\"img/{$icons[$row['s_type']]}.ico\"> <a href=\"#\">{$row['s_title']}</a><br>";           
        }
    }
    else
    {
        echo 'Der findes ikke nogen service beskeder';
    }
?>
Avatar billede delphiuser Mester
01. oktober 2014 - 09:51 #3
Jeg vil teste det her om ikke så lang tid har lige en søn på 3 mdr som kræver min opmærksomhed.
Avatar billede delphiuser Mester
01. oktober 2014 - 12:48 #4
repox -> jeg brugte dit eksempel. kom med et svar og du vil få pointene. det virker som det skal.
Avatar billede repox Seniormester
01. oktober 2014 - 12:53 #5
Du får et svar her.
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

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