php.de

Zurück   php.de > Webentwicklung > Datenbanken

Datenbanken SQL und Co

Antwort
 
LinkBack Themen-Optionen Thema bewerten
Alt 29.07.2004, 13:16  
Gast
 
Beiträge: n/a
Standard [Erledigt] Abfrage funktioniert nicht!

Hallo,

wieso funktioniert die folgende Abfrage nicht. Ich bekomme immer den else Teil ausgegeben. Vielen Dank

Code:
<?php

$srhp_root_path = './';

include ($srhp_root_path . '../../includes/db_verbindung.inc.php');

  
	if ($_POST['sr_nr']='0')
  		{
	  		echo ('<h2>Hier soll ein Formular hin...</h2>');
		}
	 elseif (($_POST['sr_nr'] !='0') and ($_POST['sr_nr'] !=''))
		 {
				sr_db_connect() or exit ();
				
				$result = mysql_query('Select `vorname`, `name` FROM `sr_liste` WHERE \''.$_POST['sr_nr'].'\' = `sr_nr`');
				
	  			$row = mysql_fetch_array($result);
				
					$sr = ($row['vorname'].' '.$row['name']); 
					
					$zeit_stunden = substr($_POST['zeit'],0,2);
					$zeit_minuten = substr($_POST['zeit'],3,2);
					$zeit = ($zeit_stunden.':'.$zeit_minuten);
			  		
					if ($row !='')
						{
						  $query = ('UPDATE `xyz` SET 
						  			`datum`= \''.$_POST['datum_jahr'].'-'.$_POST['datum_monat'].'-'.$_POST['datum_tag'].'\', 
									`zeit`= \''.$zeit.'\', 
									`mannschaft_a`=\''.$_POST['mannschaft_a'].'\', 
									`mannschaft_b`=\''.$_POST['mannschaft_b'].'\', 
									`sr_nr`=\''.$_POST['sr_nr'].'\', 
									`sr`= \''.$sr.'\' 
									WHERE \''.$_POST['id'].'\' = `id`');
									
							$aendern = mysql_query($query)
			  				or die ('Fehler beim Schreiben in die Datenbank');
				 		}
					else
						{
							echo ('<h2>Fehler</h2>');
							echo ('<h4>Es existiert keine Nummer '.$_POST['sr_nr'].'</h4>');
						}
			}
		elseif ($_POST['sr_nr'] ='')
			echo ('<h2>Keine SR-Nr. eingegeben. </h2>');
			
		else
			{
			echo ('<h2>Fehler hier</h2>');
			}
?>
  Mit Zitat antworten
Sponsor Mitteilung
PHP Code Flüsterer

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

Alt 29.07.2004, 13:43  
Erfahrener Benutzer
 
Benutzerbild von lazydog
 
Registriert seit: 02.04.2008
Beiträge: 4.032
lazydog befindet sich auf einem aufstrebenden Ast
Standard

Ich könnte jetzt fragen, welche Abfrage nicht funktioniert. Aber das spielt gar keine Rolle, weil keine ausgeführt wird. In
PHP-Code:
if ($_POST['sr_nr']='0'
wird mal der Variablen '0' zugewiesen und die Abfrage ist immer TRUE.
Weiter: $row ist ein Array und kann deshalb nicht mit
PHP-Code:
if ($row !=''
abgefragt werden.
So müsste das Ganze eigentlich laufen und ist erst noch lesbar:
PHP-Code:
<?php

$srhp_root_path 
'./';
include (
$srhp_root_path '../../includes/db_verbindung.inc.php');

if (
$_POST['sr_nr'] == '0')
{
    echo (
'<h2>Hier soll ein Formular hin...</h2>');
}
elseif ((
$_POST['sr_nr'] != '0') and ($_POST['sr_nr'] != ''))
{
    
sr_db_connect() or exit ();           
    
$result mysql_query("Select  vorname , name  
                           FROM  sr_liste  
                           WHERE '" 
$_POST['sr_nr'] . "' =  sr_nr");  
    if (
mysql_num_rows($result))
    {          
        
$row mysql_fetch_array($result);            
        
$sr = ($row['vorname'] . ' ' $row['name']);               
        
$zeit_stunden substr($_POST['zeit'],0,2);
        
$zeit_minuten substr($_POST['zeit'],3,2);
        
$zeit = ($zeit_stunden ':' $zeit_minuten);
     
        
$query = ("UPDATE xyz SET
                 datum = '" 
$_POST['datum_jahr']  . '-' $_POST['datum_monat'] . '-' 
                         
$_POST['datum_tag'] . "',
                 zeit = '" 
$zeit "',
                 mannschaft_a = '" 
$_POST['mannschaft_a'] . "',
                    mannschaft_b = '" 
$_POST['mannschaft_b'] . "',
                 sr_nr = '" 
$_POST['sr_nr'] . "',
                 sr =  $sr 
                 WHERE id = '" 
$_POST['id'] . "'");
                           
        
$aendern mysql_query($query)
                       or die (
'Fehler beim Schreiben in die Datenbank');
    }
    else
    {
       echo (
'<h2>Fehler</h2>');
       echo (
'<h4>Es existiert keine Nummer ' $_POST['sr_nr'] . '</h4>');
    }
}
elseif (
$_POST['sr_nr'] = '')
{
    echo (
'<h2>Keine SR-Nr. eingegeben. </h2>');
}         
else
{
    echo (
'<h2>Fehler hier</h2>');
}
?>
__________________
Gruss
L
lazydog ist offline   Mit Zitat antworten
Alt 29.07.2004, 14:01  
Gast
 
Beiträge: n/a
Standard

Vielen Dank, das bringt mich meinem Ziel schon mal ein Stück näher.

Allerdings kommt folgende Fehlermeldung:
Zitat:
Warning: mysql_num_rows(): supplied argument is not a valid MySQL result resource in .../test_03.php on line 29
Zeile 29 ist:

Code:
 if (mysql_num_rows($result))
  Mit Zitat antworten
Alt 29.07.2004, 14:36  
Erfahrener Benutzer
 
Benutzerbild von lazydog
 
Registriert seit: 02.04.2008
Beiträge: 4.032
lazydog befindet sich auf einem aufstrebenden Ast
Standard

Habe ich übersehen: Kein mysql_query() ohne anschliessende Abfrage von mysql_error(). Und gib gleich noch das evaluierte Statement mit aus:
PHP-Code:
$sql "Select  vorname , name  
                           FROM  sr_liste  
                           WHERE '" 
$_POST['sr_nr'] . "' =  sr_nr";
echo 
"$sql
"
;  // für Testzwecke
$result mysql_query($sql) or die(mysql_error()); 
Die Fehlermeldung heisst im wesentlichen, dass die Abfrage fehlerhaft ist und mysql_query() nicht funktioniert hat.
__________________
Gruss
L
lazydog ist offline   Mit Zitat antworten
Alt 29.07.2004, 14:49  
Gast
 
Beiträge: n/a
Standard

Zitat:
Query was empty
Kann es sein, dass der Wert von $_POST['sr_nr'] aus dem Formular in der if-Klammer nicht mehr gültig ist?

Die Abfrage müsste nämlich stimmen und einen Datensatz gibts auch dazu in der DB, habs eben kontrolliert...

Woran könnte es sonst noch liegen?
  Mit Zitat antworten
Alt 29.07.2004, 14:57  
Gast
 
Beiträge: n/a
Standard

Hab den Fehler gefunden!

Vielen Dank für Deine Hilfe, es funktioniert jetzt!!!
  Mit Zitat antworten
Alt 29.07.2004, 14:59  
Erfahrener Benutzer
 
Benutzerbild von lazydog
 
Registriert seit: 02.04.2008
Beiträge: 4.032
lazydog befindet sich auf einem aufstrebenden Ast
Standard

Was gibt denn
PHP-Code:
echo "$sql
"
;  // für Testzwecke 
aus
__________________
Gruss
L
lazydog ist offline   Mit Zitat antworten
Antwort


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
[Erledigt] mysql abfrage über 4 Tabelle - bis 3 geht, bei der 4. habert Datenbanken 2 08.09.2005 11:59
Kontakrformular funktioniert nur zum Teil PHP Tipps 2005-2 12 18.07.2005 11:24
[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
Abfrage funktioniert unter MySQL aber nicht unter MS SQL Schiedsrichter Datenbanken 2 27.01.2005 15:43
[Erledigt] Mysql Abfrage Problem! PHP-Fortgeschrittene 5 27.11.2004 10:22
Abfrage funktioniert nicht Datenbanken 9 16.08.2004 17:00
Abfrage funktioniert zwar, aber nicht korrekt Datenbanken 2 16.08.2004 09:10
Abfrage gestalten Datenbanken 3 13.08.2004 13:33
Newbie-Frage: Abfrage funktioniert nicht Datenbanken 3 13.08.2004 12:28
2 Tabellen 1 Abfrage nilsfeld Datenbanken 6 11.08.2004 11:18
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

Besucher kamen über folgende Suchanfragen bei Google auf diese Seite
h2 query datum/zeit, where =\ .$_post [], where $_post, sql abfrage funktioniert über php nicht

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