php.de

Zurück   php.de > Webentwicklung > PHP Einsteiger > PHP Tipps 2004

 
 
LinkBack Themen-Optionen Thema bewerten
Alt 19.10.2004, 18:29  
Gast
 
Beiträge: n/a
Standard if abfrage stimmt nicht!

Ich bekomme bei diesem script immer alle kurse angezeigt. Was ist an der if abfrage falsch?
PHP-Code:
function Kurstitel()
{
            
$tmprslt .="<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\">\n";
            
$tmprslt .="<tr>\n";
            
$tmprslt .="<td width=\"200\" valign=\"baseline\">\n";
            
$tmprslt .="<h2>[i]Kursübersicht[/i]</h2>\n";
            
$tmprslt .="</td>\n";
            
$tmprslt .="<td valign=\"baseline\">\n";
            
$tmprslt .="<form action=\"index.php?cmd=kurs\" method=\"post\">\n";
            
$tmprslt .="[b]Wähle Dein Kursniveau:[/b]\n";
            
$tmprslt .="<input name=\"kurswahl\" type=\"hidden\" value=\"1\">\n";
            
$tmprslt .="<select name=\"kurs\">\n";
            
$tmprslt .="<option value=\"0\" selected>Alle anzeigen</option>\n";
            
$tmprslt .="<option value=\"Basic\">Basic</option>\n";
            
$tmprslt .="<option value=\"Mittelstufe 1\">Mittelstufe 1</option>\n";
            
$tmprslt .="<option value=\"Mittelstufe 2\">Mittelstufe 2</option>\n";
            
$tmprslt .="<option value=\"Fortgeschritten 1\">Fortgeschritten 1</option>\n";
            
$tmprslt .="<option value=\"Fortgeschritten 2\">Fortgeschritten 2</option>\n";
            
$tmprslt .="<option value=\"Lady Style\">Lady Style</option>\n";
            
$tmprslt .="<option value=\"Men Style\">Men Style</option>\n";
            
$tmprslt .="</select>\n";
            
$tmprslt .="<input type=\"submit\" name=\"Submit\" value=\"Go\">\n";
            
$tmprslt .="</form>\n";
            
$tmprslt .="</td>\n";
            
$tmprslt .="</tr>\n";
            
$tmprslt .="</table>\n";
            
    return 
$tmprslt;
}

//laden der Kursübersicht 
function kurse()
{
        include(
'inc/database.inc.php');
        
$tmprslt '';
        
$connection mysql_connect($db['host'],$db['uid'],$db['pwd']);
        if(
$connection)
        {
                    global 
$kurs;
                    
//Auswertung der Kurswahl
                    
if($_POST['kurswahl']==&& $_POST['kurs']==0)
                    {
                        
$date=date("Y-m-d",time()-date(2*24*60*60));
                        
mysql_select_db($db['db']);
                        
$sql "SELECT 
                              k_id, 
                              k_name, 
                              k_zeit, 
                              UNIX_TIMESTAMP(k_beginn) AS k_newbeginn, 
                              UNIX_TIMESTAMP(k_ende) AS k_newende, 
                              k_preis 
                            FROM 
                              kurse 
                            WHERE 
                              k_beginn > '"
.$date."'
                            ORDER BY 
                              k_beginn ASC, 
                              k_zeit ASC 
                           "

                    }
                    
                    if(
$_POST['kurswahl']==&& $_POST['kurs']!=0)
                    {
                        
$date=date("Y-m-d",time()-date(2*24*60*60));
                        
mysql_select_db($db['db']);
                        
$sql "SELECT 
                              k_id, 
                              k_name, 
                              k_zeit, 
                              UNIX_TIMESTAMP(k_beginn) AS k_newbeginn, 
                              UNIX_TIMESTAMP(k_ende) AS k_newende, 
                              k_preis 
                            FROM 
                              kurse 
                            WHERE 
                              k_beginn > '"
.$date."' AND k_name = '".$_POST['kurs']."'
                            ORDER BY 
                              k_beginn ASC, 
                              k_zeit ASC 
                           "

                    }
                    else
                    {
                        
$date=date("Y-m-d",time()-date(2*24*60*60));
                        
mysql_select_db($db['db']);
                        
$sql "SELECT 
                              k_id, 
                              k_name, 
                              k_zeit, 
                              UNIX_TIMESTAMP(k_beginn) AS k_newbeginn, 
                              UNIX_TIMESTAMP(k_ende) AS k_newende, 
                              k_preis 
                            FROM 
                              kurse 
                            WHERE 
                              k_beginn > '"
.$date."'
                            ORDER BY 
                              k_beginn ASC, 
                              k_zeit ASC 
                           "

                    } 
 
Sponsor Mitteilung
PHP Code Flüsterer

Registriert seit: 21.08.2005
Beiträge: 4682
PHP-Kenntnisse:
Fortgeschritten

Alt 19.10.2004, 18:45  
Gast
 
Beiträge: n/a
Standard

Mit etwas nachdenken kann man darauf kommen. :wink:
Wenn if($_POST['kurswahl']==1 && $_POST['kurs']==0) zutrifft
PHP-Code:
    if($_POST['kurswahl']==&& $_POST['kurs']==0
    { 
         
// trifft zu
    

                     
    if(
$_POST['kurswahl']==&& $_POST['kurs']!=0
    { 
        
// trifft dann nicht zu
    

    else 
    { 
       
// also
       // Das Script kommt in dem Fall hier hin!
    

Besser ist also:
PHP-Code:
    if($_POST['kurswahl']==&& $_POST['kurs']==0
    { 
         
// trifft zu
    

    else if(
$_POST['kurswahl']==&& $_POST['kurs']!=0
    { 
        
// trifft dann nicht zu
    

    else 
    { 
        
// trifft dann auch nicht zu
    

Gruß
phpfan
 
Alt 19.10.2004, 18:57  
Gast
 
Beiträge: n/a
Standard

das problem ist das ich 3 zustände haben kann:

1. $_POST['kurs'] ist nicht vorhanden, wenn der besucher frisch in die seite linkt. alle niveaus werden ausgegeben.

2. $_POST['kurs'] ist 0, wenn nur auf "go" geklickt wird. alle niveaus werden ausgegeben.

3. $_POST['kurs'] ist nicht 0, wenn nur auf "das niveau" geklickt wird. nur das gewählte niveau soll ausgegeben werden.

im moment werden immer alle niveaus ausgegeben.
 
Alt 19.10.2004, 18:59  
Gast
 
Beiträge: n/a
Standard

Hast Du ausprobiert, was ich dir geschrieben habe?
Gruß
phpfan
 
Alt 19.10.2004, 19:13  
Gast
 
Beiträge: n/a
Standard

ja, es hat sich jedoch nichts verändert. immer noch gleiches problem
 
Alt 19.10.2004, 20:21  
Gast
 
Beiträge: n/a
Standard

Zitat:
Zitat von andyM
das problem ist das ich 3 zustände haben kann:

1. $_POST['kurs'] ist nicht vorhanden, wenn der besucher frisch in die seite linkt. alle niveaus werden ausgegeben.

2. $_POST['kurs'] ist 0, wenn nur auf "go" geklickt wird. alle niveaus werden ausgegeben.
Code:
if (!isset($_POST['kurs'] OR $_POST['kurs'] == 0)
   zeige_alles_an();
Zitat:
3. $_POST['kurs'] ist nicht 0, wenn nur auf "das niveau" geklickt wird. nur das gewählte niveau soll ausgegeben werden.
Code:
if (isset($_POST['kurs'] OR $_POST['kurs'] > 0)
   zeige_niveau_an($_POST['kurs']);
Ist doch einfach...?
 
 


Themen-Optionen
Thema bewerten
Thema bewerten:

Forumregeln
Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are an
Gehe zu

Ähnliche Themen
Thema Autor Forum Antworten Letzter Beitrag
Abfrage von einer Abfrage Datenbanken 5 27.01.2011 23:31
mysql abfrage in Schleife havok PHP Tipps 2006 6 09.05.2006 08:39
abfrage begrenzen Cyrus Datenbanken 4 26.10.2005 11:29
[Erledigt] mysql abfrage über 4 Tabelle - bis 3 geht, bei der 4. habert Datenbanken 2 08.09.2005 11:59
Abfrage in array? BartTheDevil89 Datenbanken 5 10.05.2005 14:21
[Erledigt] IF() abfrage in variable packen PHP Tipps 2005 14 01.04.2005 17:23
Abfrage von Char-Feldern Datenbanken 9 04.02.2005 14:06
[Erledigt] SQL Abfrage funzt nicht Datenbanken 2 04.02.2005 11:09
[Erledigt] Mysql Abfrage Problem! PHP-Fortgeschrittene 5 27.11.2004 10:22
Abfrage funktioniert zwar, aber nicht korrekt Datenbanken 2 16.08.2004 09:10
Abfrage aus DB noch mal ausgeben und Abfrage aus mehrern Tab PHP Tipps 2004 4 12.07.2004 15:00
komplizierte mySQL Abfrage Datenbanken 6 25.06.2004 15:34
[Erledigt] Fehlerhafte Abfrage ? Datenbanken 15 24.06.2004 17:10
[Erledigt] mysql Abfrage Datenbanken 5 18.06.2004 14:16
[Erledigt] Variable per GET übergeben und DB Abfrage nutzen PHP Tipps 2004 4 01.06.2004 15:17

Besucher kamen über folgende Suchanfragen bei Google auf diese Seite
if php stimmt nicht, kurswahl sql, php if nicht stimmt, abfrage kursübersicht, php kurswahl

Alle Zeitangaben in WEZ +2. Es ist jetzt 00:25 Uhr.




Powered by vBulletin® Version 3.7.2 (Deutsch)
Copyright ©2000 - 2012, Jelsoft Enterprises Ltd.
Search Engine Optimization by vBSEO 3.2.0
Aprilia-Forum, Aquaristik-Forum, Liebeskummer-Forum, Zierfisch-Forum, Geizkragen-Forum

Creative Commons License
Dieser Inhalt ist unter einer Creative Commons-Lizenz lizenziert.