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

Update Node mit multiple Taxonomy terms

Eingetragen von cpritz (91)
am 31.05.2013 - 14:07 Uhr in
  • Modul-Entwicklung
  • Drupal 7.x

Ich habe ein Modul geschrieben, dass zunächst alle Werte eines Taxonomy Refrence Feldes löscht. Das Feld ist also anschließend leer.
Nun möchte ich neue Werte, und zwar mehrere hinzufügen.

foreach($termids as $termid){
        $fieldname = 'feldname';
$fieldtable = 'field_data_fieldname';
$key = db_query("SELECT * FROM {$fieldtable} WHERE entity_id = :eid", array(':eid' => $nid))->rowCount(); //$nid ist bekannt!!!
$node->$fieldname = array(
'und' => array(
                     $key => array(
'tid' => $tid,
),
),
);
node_save($node);
$node = node_load($nid);
}

Die Schleife wird komplett durchlaufen. Allerdings wird lediglich der letzte Wert in das Feld geschrieben und nicht alle (mehrere) Werte wie erwartet. Das Feld an sich kann eine unbegrenzte Anzahl von Werten aufnehmen. Der $key wird nicht gesetzt. Wenn ich das debugge, steht für den $key immer eine 0.
Wie schaffe ich es in einem Feld mehrere Werte einzusetzen und den Node dann zu speichern?
Es geht hierbei nicht darum einen node zu erzeugen, sondern einen node zu bearbeiten.

Nachdem ich jetzt tagelang das Netz durchforstet habe, bin ich für jede Hilfe dankbar!!!

‹ [GELÖST]InnerJoin Problem Autocomplete Textfield will nicht richtig ›
  • Anmelden oder Registrieren um Kommentare zu schreiben

Ich vermute es liegt an der

Eingetragen von thisisablock (4)
am 31.05.2013 - 16:04 Uhr

Ich vermute es liegt an der deiner foreach Schleife

Du gehst alle Terms durch und speicherst immer jeden einzelnen in die Node.
Durch das node_save() werden dann die alten Terms aus der Node natürlich gelöscht und
am Ende bleibt der letzte stehen !

Am besten erstmals alles sammeln und dann einmal am Ende speichern.
Hier mal ein ungetestetes Beispiel.

$fieldname = 'feldname';
$keys = array();
foreach($termids as $termid) {
  $keys[] = array( 'tid' => db_query("SELECT * FROM field_data_fieldname WHERE entity_id = :eid", array(':eid' => $nid))->rowCount() );
}

$node->$fieldname = array(
  LANGUAGE_NONE => $keys
);
node_save($node);

  • Anmelden oder Registrieren um Kommentare zu schreiben

Ich vermute es liegt an der

Eingetragen von thisisablock (4)
am 31.05.2013 - 16:03 Uhr

# Doublepost

  • Anmelden oder Registrieren um Kommentare zu schreiben

kannst du das nicht einfacher

Eingetragen von caw (2762)
am 31.05.2013 - 16:42 Uhr

kannst du das nicht einfacher mit views_bulk_operations machen?

  • Anmelden oder Registrieren um Kommentare zu schreiben

[geloest]

Eingetragen von cpritz (91)
am 31.05.2013 - 16:45 Uhr

DANKE!!! Das Wochende kann kommen :-)))

Es lag am Aufbau des Arrays.

  • Anmelden oder Registrieren um Kommentare zu schreiben

Benutzeranmeldung

  • Registrieren
  • Neues Passwort anfordern

Aktive Forenthemen

  • How to Spend a Great Evening at Crash Online Games
  • Neuinstallation: vermutlich ein rewrite-Problem
  • Drupal CMS installieren
  • [erledigt]MP3 in Drupal 10 einbinden
  • (gelöst)Drupal 11 installieren
  • Titel ausblenden
  • Ich brauche dringen Hilfe zu Updates oder ggf. wwie geht Composer?
  • Dynamische Ansicht von Seiteninhalt (als Tabelle?)
  • Vergabe von Berechtigungen für bestimmte Rollen; mir fehlt der Haken bzw. das „Veröffentlicht“
  • Medien und andere Daten mit Feeds von Drupal 7 auf Drupal 10 migrieren
  • Rolle erstellen nicht zu finden
  • für drupal11 ein Slider Modul
Weiter

Neue Kommentare

  • Was für einen Server benutzt
    vor 1 Woche 1 Tag
  • Wenn die Subdomain auf
    vor 1 Woche 2 Tagen
  • ordnerstruktur
    vor 1 Woche 3 Tagen
  • Die Subdomain muß auf den
    vor 1 Woche 5 Tagen
  • Verwende doch das Tag dafür,
    vor 5 Wochen 15 Stunden
  • Guckst du hier: step by step
    vor 5 Wochen 5 Stunden
  • Guckst du hier: step by step
    vor 5 Wochen 5 Stunden
  • Ich habe ja keine Angst vor
    vor 6 Wochen 2 Tagen
  • Ist grundsätzlichmachbar – aber nichts für „einfach mal schnell“
    vor 6 Wochen 4 Tagen
  • Vielen Dank erst einmal, aber
    vor 6 Wochen 6 Tagen

Statistik

Beiträge im Forum: 250290
Registrierte User: 20517

Neue User:

  • RollingSlots
  • Wolf Dab
  • Scottteday

» Alle User anzeigen

User nach Punkten sortiert:
wla9466
stBorchert6003
quiptime4972
Tobias Bähr4019
bv3924
ronald3857
md3717
Thoor3678
Alexander Langer3416
Exterior2903
» User nach Punkten
Zur Zeit sind 0 User und 26 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