php.de

Zurück   php.de > Webentwicklung > PHP Einsteiger > PHP Tipps 2005-2

 
 
LinkBack Themen-Optionen Thema bewerten
Alt 04.06.2005, 13:22  
Benutzer
 
Registriert seit: 04.06.2005
Beiträge: 30
JonathanArcher
Standard Immer nur der erste Teil der if-Abfrage?

Hi!
Ich habe eine Frage. (Was sonst?!)
Ich will ein Zitate-System aufbauen nach dem folgenden Muster:
Autor
zitat
zitat
zitat

Autor
zitat

usw.

dafür habe ich die Zitate in eine MySQL- Datenbank geschrieben und lese sie mit einer while-Schleife aus. Um zu testen ob ein neuer Autor vorliegt habe ich eine Variable $AUT_CHECK = "" angelegt. Am Ende jedes Durchlaufes der while-Schleife wird sie auf den aktuellen Autor gesetzt und in jedem Durchlauf gecheckt ob ein neuer Autor vorliegt und dementsprechend gehandelt.
ABER: Irgendwie wird nie der else Teil dieser zweiten If-Abfrage ausgeführt. IMMER nur der erste Teil.

PHP-Code:
         if(mysql_num_rows($result)) { // gucken ob was im Query drinsteckt
                
while($row mysql_fetch_assoc($result)) {
                        if(
$AUTH_CHECK != $row['Autor']) { //schauen ob ein neuer Autor vorliegt
                            
echo "

"
.$row['AUTOR']."<a name=\"".$row['AUTOR']."\"></a>
\n"
//mit Autor ausgeben
                            
echo $row['ZITAT']." von ".$row['AUTOR']."</p>\n";
                        } else {
                            echo 
"

"
.$row['ZITAT']." von ".$row['AUTOR']."</p>\n"//ohne Autor ausgeben
                        
}
                
$AUT_CHECK $row['AUTOR']; //Aut_Check auf aktuellen Autor setzen
                
}
         } else {
          echo 
"Es sind keine Zitate in der Datenbank vorhanden
\n"
;
     }
     echo 
$AUT_CHECK //zum Überprüfen AUT_CHECK ausgeben 
JonathanArcher ist offline  
Sponsor Mitteilung
PHP Code Flüsterer

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

Alt 04.06.2005, 13:38  
Gast
 
Beiträge: n/a
Standard

if(mysql_num_rows($result))

was wenn 0 ?

if(mysql_num_rows($result)>0)
 
Alt 04.06.2005, 13:49  
Gast
 
Beiträge: n/a
Standard

Ist zwar empfehlenswert, wenn der Vergleich voll ausgeschrieben dasteht, aber if(mysql_num_rows($result)) ist auch gültig, da 0 zu false evaluiert und Werte größer 0 zu true.


Reagiert Dein Skript auf Fehler bei der mysql-Abfrage? Wenn nicht, möchte Dir mysql evtl. etwas mitteilen und Du siehst es nicht.
Einfachste Form ist: Fehlerausgabe und Skriptende
PHP-Code:
<?php
$db 
mysql_connect(...,...,...) or die(mysql_error());
mysql_select_db(..., $db) or die(mysql_error());

$query = ...
$result mysql_query($query$db) or die(mysql_error());

if(
mysql_num_rows($result)) {
    
} else {
    echo 
'Debug: die Abfrage "'$query'" hat keine Datensätze geliefert';
}
?>
 
Alt 04.06.2005, 13:51  
Benutzer
 
Registriert seit: 04.06.2005
Beiträge: 30
JonathanArcher
Standard

Zitat:
Zitat von J33d3X
if(mysql_num_rows($result))

was wenn 0 ?

if(mysql_num_rows($result)>0)
Stimmt. Das is nich ganz korrekt. Aber das hat doch auch keinen Einfluss auf das Problem, oder?
JonathanArcher ist offline  
Alt 04.06.2005, 14:05  
Benutzer
 
Registriert seit: 04.06.2005
Beiträge: 30
JonathanArcher
Standard

Zitat:
Zitat von VolkerK
Ist zwar empfehlenswert, wenn der Vergleich voll ausgeschrieben dasteht, aber if(mysql_num_rows($result)) ist auch gültig, da 0 zu false evaluiert und Werte größer 0 zu true.
...
mhm... ich hab mir php vor ca. ner Woche beigebracht... ich hab (fast) keine Ahnung was du meinst. sry...
Ich geb euch mal die ganze Site, vielleicht liegt der Fehler ja woanders. Auch wenn ich das für sehhhr unwahrscheinlich halte...

PHP-Code:
<?php
error_reporting
(E_ALL);
include 
"config.php";

     @
mysql_connect(MYSQL_HOSTMYSQL_USERMYSQL_PASS) OR die(mysql_error());
     
mysql_select_db(MYSQL_DATABASE) OR die(mysql_error());

          
$sql "SELECT
                     AUTOR,
                     ZITAT,
                     TAG
                FROM
                     quotes_lehrer
                ORDER BY
                     AUTOR DESC"
;

    
$result mysql_query($sql) OR die(mysql_error());

                        
$AUTH_CHECK "";

         if(
mysql_num_rows($result)>0) { // gucken ob was im Query drinsteckt
                
while($row mysql_fetch_assoc($result)) {
                        if(
$AUTH_CHECK != $row['AUTOR']) { //schauen ob ein neuer Autor vorliegt
                            
echo "

"
.$row['AUTOR']."<a name=\"".$row['AUTOR']."\"></a>
\n"
//mit Autor ausgeben
                            
echo $row['ZITAT']." von ".$row['AUTOR']."</p>\n";
                        } else {
                            echo 
"

"
.$row['ZITAT']." von ".$row['AUTOR']."</p>\n"//ohne Autor ausgeben
                        
}
                
$AUT_CHECK $row['AUTOR']; //Aut_Check auf aktuellen Autor setzen
                
}
         } else {
          echo 
"Es sind keine Datens&auml;tze vorhanden 
\n"
;
     }
     echo 
$AUT_CHECK
?>
JonathanArcher ist offline  
Alt 04.06.2005, 14:28  
Benutzer
 
Registriert seit: 04.06.2005
Beiträge: 30
JonathanArcher
Standard

Nein... das tut echt weh... ich gehöre mit dem Kopf gegen die Wand geklatscht... ich bin mit den Wörtern Autor und author also Deutsch und Englisch durcheinander gekommen und habe diese Variable mal AUT_... dann wieder AUTH_... genannt... tut mir echt leid Leute!
__________________
Die Borg würden nicht einmal Spaß verstehen, wenn sie einen ganzen Funpark assimilieren würden. --B'Elana Torres --
JonathanArcher ist offline  
 

« sessions.. | MySql »

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
Teil einer Spalte auslesen Datenbanken 7 07.02.2006 18:22
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
2 Tabellen 1 Abfrage nilsfeld Datenbanken 6 11.08.2004 11:18
Abfrage aus DB noch mal ausgeben und Abfrage aus mehrern Tab PHP Tipps 2004 4 12.07.2004 15:00
[Erledigt] Fehlerhafte Abfrage ? Datenbanken 15 24.06.2004 17:10
[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
mysql_num_rows if-abfrage, if abfrage mysql_num_rows, mysql abfrage autor mitautor, php nur das erste if, mysql_num_rows als if abfrage, $row = mysql_fetch_assoc if abfrage, php if abfrage immer nur else code wird ausgeführt, php if nur 2 stellen, if abfrage datenbank, php teil variablenname abfrage, php if nur teil vergleichen, php mit if teil eines feldes abfragen, php if nur teil, if teil der url dann

Alle Zeitangaben in WEZ +2. Es ist jetzt 04:15 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.