Startseite
  • » Home
  • » Handbuch & FAQ
  • » Forum
  • » Übersetzungsserver
  • » Suche
Startseite › Forum › Drupalcenter.de › Module › Modul-Entwicklung ›

[gelöst]Datenbankwerte in eine Selectbox einlesen

Eingetragen von th3o2211 (87)
am 29.08.2012 - 13:00 Uhr in
  • Modul-Entwicklung
  • Drupal 7.x

Hallo Drupalfreunde,

danke erstmal, dass ihr meine anfängerfrage Anschaut :-)

nun zu meinem Probelm:

Ich möchte aus meiner Datenbank Wete auslesen und diese in eine Auswahlliste. hier ist mein Code den ich soweit schon habe:

<?php

    $sql_weather
= db_select("wetterdaten_staedte", "u")->fields('u', array("id" ,"staedte"))->execute()->fetchAll();
    foreach(
$sql_weather as $result_weather) {
   
$plz = $result_weather->staedte;
   
   
   
$form['staedte_option'] = array(
      
'#type'  => 'value',
      
'#value' => array(t($plz))
    );
   
$form['staedte_name'] = array(
      
'#title'       => t('Ort/Stadt'),
      
'#type'        => 'select',
      
'#description' => t('Bitte wählen Sie eine/n Stadt/Ort aus.'),
      
'#options'     => $form['staedte_option']['#value']
    );
    }

?>

Leider wird ja bei meinem Code nur das letzte ergebnis in die Selectbox geschrieben.

Meine Frage:
Gibt es noch eine andere möglichekit sachen dynamisch in so eine liste laden zu lassen? Was habe ich hier falsch gemacht?

Über eine Anmerkung zu meinem Fehler würde ich mich freuen :-)

‹ geoField. Position im Profil aktualisieren Modul greift auf Hook->db_query aber nicht auf aktuellen Datensatz? Ab wann kann ich es erreichen? ›
  • Anmelden oder Registrieren um Kommentare zu schreiben

Du musst die foreach-Schleife

Eingetragen von wla (9461)
am 29.08.2012 - 13:57 Uhr

Du musst die foreach-Schleife umbauen. Dort darfst Du nur die Postleitzahlen in einen Array packen, den Du dann bei den options angibst. Die Form muss außerhalb dieser Schleife stehen.

Beste Grüße
Werner

  • Anmelden oder Registrieren um Kommentare zu schreiben

Hallo werner! das hatte ich

Eingetragen von th3o2211 (87)
am 29.08.2012 - 14:09 Uhr

Hallo werner!

das hatte ich zwischenzeitlich schon probiert mein codestelle sieht nun so aus

<?php

    $sql_weather
= db_select("wetterdaten_staedte", "u")->fields('u', array("id" ,"staedte"))->execute()->fetchAll();
    foreach(
$sql_weather as $result_weather) {
   
$plz = $result_weather->staedte;
   
$plz_test = array($plz);
    }
   
$form['staedte_option'] = array(
      
'#type'  => 'value',
      
'#value' => array($plz_test)
    );
   
$form['staedte_name'] = array(
      
'#title'       => t('Ort/Stadt'),
      
'#type'        => 'select',
      
'#description' => t('Bitte wählen Sie eine/n Stadt/Ort aus.'),
      
'#options'     => $form['staedte_option']['#value']
    );
   
$form['submit'] = array(
       
'#type'     => 'submit',
       
'#value'    => t('Absenden'),
    );

?>

wenn ich diesen code ausführe bekomme ich nur warnings und es geht nicht mehr.

  • Anmelden oder Registrieren um Kommentare zu schreiben

Ich weiß ehrlich nicht, was

Eingetragen von wla (9461)
am 29.08.2012 - 14:45 Uhr

Ich weiß ehrlich nicht, was das Konstrukt

Zitat:

$form['staedte_option'] = array(
'#type' => 'value',
'#value' => array($plz_test)
);

überhaupt soll. Das hat da nichts zu suchen. Du weist mittels '#options'     => $plz_test, die Optionen direkt zu. Außerdem sollte man nach Coding Standards immer ein Komma am Ende der Zeile im Array haben, auch wenn das beim letzten Eintrag nicht notwendig wird. So vermeidet man Probleme, wenn man mal "auf die Schnelle" etwas ändert und das fehlende Komma dabei übersieht.

Beste Grüße
Werner

  • Anmelden oder Registrieren um Kommentare zu schreiben

Danke

Eingetragen von th3o2211 (87)
am 29.08.2012 - 15:02 Uhr

ok ja ich habs gemerkt. Ich hab dieses konstrukt aus dem Pro Drupal 7 Development abgekupfert und versucht es für meine zwecke zu missbrauchen.

Hab jetzt nochmal bisschen rumprobiert und das rausbekommen:

<?php

    $sql_weather
= db_select("wetterdaten_staedte", "u")->fields('u', array("id" ,"staedte"))->execute()->fetchAll();
   
   
$p = 0;
   
$plz = array();
    foreach(
$sql_weather as $result_weather) {
   
$plz[$p] = $result_weather->staedte;
   
//echo $plz;
   
$p++;
    }

   
$form['staedte_name'] = array(
      
'#title'       => t('Ort/Stadt'),
      
'#type'        => 'select',
      
'#required'     => TRUE,
      
'#description' => t('Bitte wählen Sie eine/n Stadt/Ort aus.'),
      
'#options'     => $plz,
    );
   
$form['submit'] = array(
       
'#type'     => 'submit',
       
'#value'    => t('Absenden'),
    );

?>

jetzt funktioniert es auch danke für dein Engagement. :-)

  • Anmelden oder Registrieren um Kommentare zu schreiben

Benutzeranmeldung

  • Registrieren
  • Neues Passwort anfordern

Aktive Forenthemen

  • für drupal11 ein Slider Modul
  • [gelöst] W3CSS Paragraphs Views
  • Drupal 11 neu aufsetzen und Bereiche aus 10 importieren
  • Wie erlaubt man neuen Benutzern auf die Resetseite zugreifen zu dürfen.
  • [gelöst] Anzeigeformat Text mit Bild in einem Artikel, Drupal 11
  • Social Media Buttons um Insteragram erweitern
  • Nach Installation der neuesten D10-Version kein Zugriff auf Website
  • Composer nach Umzug
  • [gelöst] Taxonomie Begriffe zeigt nicht alle Nodes an
  • Drupal 11 + Experience Builder (Canvas) + Layout Builder
  • Welche KI verwendet ihr?
  • Update Manger läst sich nicht Installieren
Weiter

Neue Kommentare

  • melde mich mal wieder, da ich
    vor 2 Tagen 11 Stunden
  • Hey danke
    vor 3 Tagen 6 Stunden
  • Update: jetzt gibt's ein
    vor 4 Tagen 39 Minuten
  • Hallo, im Prinzip habe ich
    vor 1 Woche 1 Tag
  • Da scheint die Terminologie
    vor 1 Woche 1 Tag
  • Kannst doch auch alles direkt
    vor 1 Woche 5 Tagen
  • In der entsprechenden View
    vor 1 Woche 5 Tagen
  • Dazu müsstest Du vermutlich
    vor 1 Woche 5 Tagen
  • gelöst
    vor 4 Wochen 2 Tagen
  • Ja natürlich. Dass ist etwas,
    vor 4 Wochen 3 Tagen

Statistik

Beiträge im Forum: 250233
Registrierte User: 20449

Neue User:

  • Mroppoofpaync
  • 4aficiona2
  • AppBuilder

» Alle User anzeigen

User nach Punkten sortiert:
wla9461
stBorchert6003
quiptime4972
Tobias Bähr4019
bv3924
ronald3857
md3717
Thoor3678
Alexander Langer3416
Exterior2903
» User nach Punkten
Zur Zeit sind 0 User und 20 Gäste online.

Hauptmenü

  • » Home
  • » Handbuch & FAQ
  • » Forum
  • » Übersetzungsserver
  • » Suche

Quicklinks I

  • Infos
  • Drupal Showcase
  • Installation
  • Update
  • Forum
  • Team
  • Verhaltensregeln

Quicklinks II

  • Drupal Jobs
  • FAQ
  • Drupal-Kochbuch
  • Best Practice - Drupal Sites - Guidelines
  • Drupal How To's

Quicklinks III

  • Tipps & Tricks
  • Drupal Theme System
  • Theme Handbuch
  • Leitfaden zur Entwicklung von Modulen

RSS & Twitter

  • Drupal Planet deutsch
  • RSS Feed News
  • RSS Feed Planet
  • Twitter Drupalcenter
Drupalcenter Team | Impressum & Datenschutz | Kontakt
Angetrieben von Drupal | Drupal is a registered trademark of Dries Buytaert.
Drupal Initiative - Drupal Association