Top-Themen

Aktuelle Themen (A bis Z)

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit

gelöst PHP - Auswahl aus Listenfeld ausgeben

Mitglied: AndyAh

AndyAh (Level 2) - Jetzt verbinden

22.03.2013, aktualisiert 11:12 Uhr, 2798 Aufrufe, 3 Kommentare

Hi NG,

ich möchte mit folgendem Code:

01.
<?php 
02.
$daten = "adressen"; 
03.
 
04.
$db = mysql_connect ("localhost", "root", ""); 
05.
 
06.
if (!$db) {  
07.
    die('Verbindung schlug fehl: ' . mysql_error()); 
08.
09.
  
10.
$select_db = mysql_select_db($daten);  
11.
 
12.
$sql_befehl = "select * from mitglieder"; 
13.
 
14.
$result = mysql_query($sql_befehl);  
15.
echo '<form method="post" action="">'; 
16.
echo '<select name="" size="1">'; 
17.
echo '<option selected value=""></option>'; 
18.
 
19.
 
20.
while($row = mysql_fetch_array($result)) 
21.
22.
       echo '<option name="wahl" value="' .$row[3]. '">' .$row[3]. '</option>'; 
23.
	}  
24.
echo '</select>'; 
25.
echo '</form>'; 
26.
 
27.
//an der Stelle möchte ich die Auswahl ausgeben. 
28.
echo $_POST['wahl']; 
29.
?>
ausgewälte Daten aus dem Listenfeld ausgeben. Leider weiß ich nicht wie?

Die Code-Tags sind mal wieder verlohren gegangen!

Gruß
Andy
Mitglied: nxclass
22.03.2013, aktualisiert um 10:56 Uhr
... Du scheinst nicht die Interaktion von Client (Browser / HTML) und dem Server (PHP /DB) zu verstehen.

  • Dein Skript holt die Daten für das select Form Element aus der DB und sendet es an deinen Browser. (inklusive deiner $_POST Variablen, welche leer ist an dieser Stelle)
  • nun sendest Du dein Formular -> an das selbe php Skript auf dem Server
  • Dein Skript holt die Daten für das select Form Element aus der DB und sendet es an deinen Browser. (inklusive deiner $_POST Variablen, welche NUN mit den Formular Daten gefüllt ist)
usw.

Du hast also keinen Controller der prüft welche Aktion genau ausgeführt werden soll. simples Beispiel:
01.
// Controller: 
02.
if (!empty($_POST)) { 
03.
   // do something like saveing in DB 
04.
05.
// get data for View 
06.
 
07.
// View: 
08.
// Formular anzeigen
ausgewälte Daten aus dem Listenfeld ausgeben. Leider weiß ich nicht wie?
01.
if (!empty($_POST) && isset($_POST['wahl']) ) { 
02.
  // Auswahl abfragen aus DB und anzeigen 
03.
} else { 
04.
  // nur das Auswahlformular anzeigen 
05.
}
.. so zB.
Bitte warten ..
Mitglied: flow.ryan
22.03.2013 um 11:16 Uhr
Hallo,

folgendes läuft schon mal falsch:

Zeile 15: action ist leer. Wo soll das teil hingeschickt werden?! Immer(!!!) ausfüllen

Zeile 16:
01.
echo '<select name="" size="1">'; 
Warum vergibst du hier keinen Namen? Option ist ein Kind-Element von select. Wenn du mehrere option-Elemente hast, überprüfst du das ausgewählte, in dem du das Elternelement (in diesem Fall Select) abfragst. Ergo: Du gibst select den Namen "wahl" und nimmst den Namen "wahl" vom Option-Element raus. Das hat da nichts zu suchen!

Zeile 22:
01.
echo '<option name="wahl" value="' .$row[3]. '">' .$row[3]. '</option>'; 
Wie bereits erwähnt: Nimm hier den Namen 'wahl' weg und lösche das Attribut "name" komplett. Außerdem solltest du bei DB-Abfragen nicht mit dem Array-Index arbeiten, da du hier auch gehörig auf die Nase fallen kannst, wenn du was an der Query änderst. Nimm den Feldnamen - z.B. $row['name']

Zeile 28:
01.
echo $_POST['wahl']; 
Wird beim ersten Aufruf OHNE POST-Werte leer sein. Wie mein Vorredner schon sagt, du verstehst, so denke ich auch, die Interaktion nicht korrekt.

Generell: Lies dir doch bitte einmal die Tutorials durch, die ich dir schon in diversen Postings ans Herz gelegt habe. Es hilft dir und uns nichts, wenn du bei jeder Kleinigkeit (Sorry, das sind wirklich absolute Kleinigkeiten) hier eine Frage aufmachst.

Gruß,
Florian
Bitte warten ..
Mitglied: AndyAh
26.03.2013 um 10:51 Uhr
Hi,

ich hab's zum laufen.

Gruß
Andy
Bitte warten ..
Ähnliche Inhalte
PHP

Mit PHP eine Telnet abfrage machen und ausgeben

Frage von helmuthelmut2000PHP1 Kommentar

Hallo, Ich möchte folgendes machen und hätte da etwas Hilfe gebraucht. Ich habe an meiner Heizung einen Optolink Adapter ...

Switche und Hubs

Router Auswahl

Frage von kossabSwitche und Hubs9 Kommentare

Hallo Zusammen, Ich habe bis jetzt fast immer Draytek Router eingesetzt, weil sie richtig stabil, einfach zu konfigurieren sind ...

Datenbanken

Access 2010 VBA - mehrspaltiges Listenfeld über Recordset füllen

gelöst Frage von AndyAhDatenbanken2 Kommentare

Hi NG, ich bin's schon wieder ;). Wie kann ich ein Listenfeld mit Recordsets mehrspaltig füllen? Folgenden Code habe ...

Datenbanken

Access 2010 - Listenfeld an ADO-Recordset knüpfen

gelöst Frage von AndyAhDatenbanken9 Kommentare

Hi NG, wie kann ich ein Listenfeld an ein ADO-Recordset knüpfen. Die zugrundeliegende Datenquelle ist keine mit Access verknüpfte ...

Neue Wissensbeiträge
Vmware
VMware Update für den ESXi 5.5 verfügbar
Information von sabines vor 2 StundenVmware

Nach dem ganzen Hickhack um Update mit Microcode Anpassungen und Rückzug, gibt es nun für den ESXi 5.5 ein ...

CPU, RAM, Mainboards

Meltdown und Spectre: Intel zieht Microcode-Updates für Prozessoren zurück

Information von keine-ahnung vor 6 StundenCPU, RAM, Mainboards4 Kommentare

Moin, extrem lutztig. Nur gut, dass ich noch nicht beim Probanden-Bingo mitgemacht habe :-) LG, Thomas

Router & Routing
PfSense als Addon auf QNAP
Information von magicteddy vor 20 StundenRouter & Routing3 Kommentare

Moin, für Spielereien eine ganz nette Idee aber ich fürchte das soetwas auch als echte Firewall genutzt wird: In ...

Datenschutz

Teamviewer kommt für IoT-Geräte wie den Raspberry Pi

Information von magicteddy vor 1 TagDatenschutz1 Kommentar

Moin, jetzt werden IoT Geräte endgültig zur Wanze? Anscheinend kann man auf einem Dashboard seine Geräte visualisieren Ich stelle ...

Heiß diskutierte Inhalte
Netzwerkmanagement
Preis für Wartungsvertrag ok?
gelöst Frage von a-za-zNetzwerkmanagement26 Kommentare

Hallo! Mal ne Frage, weil ich mich mit dem akzeptablen Preis für einen Reaktionszeitvertrag nicht auskenne. Meine Firma hat ...

Windows Server
TEMP-Profile
gelöst Frage von Forseti2003Windows Server21 Kommentare

Guten Morgen, wer kennt sie nicht, die lieben Temporären Benutzerprofile, vorallem immer dann, wenn man sie am wenigsten braucht. ...

Multimedia & Zubehör
Welches Tablet für die Verkäufer?
Frage von Hendrik2586Multimedia & Zubehör15 Kommentare

Guten Morgen meine Lieben, vielleicht könnt ihr mir ja helfen. Es geht um unsere Außendienstmitarbeiter /Verkäufer. Sie sollen demnächst ...

Windows Netzwerk
Ist ein Portforwarding auf einen PC ohne lauschendes Programm ein (großes) Sicherheitsproblem?
Frage von PluwimWindows Netzwerk13 Kommentare

Hallo zusammen, zur Fernwartung eines Rechners an einem anderen Ort nutze ich VNC. Da dieser Rechner einfach nur eine ...