Will automatisch nodes erstellen und updaten lassen, aber node_save reagiert komisch!???
am 11.10.2013 - 17:33 Uhr in
Hi Leute, jetzt wird es verzwickt. Vielleicht weiß einer Rat!???
Ich möchte in einem selbst gebauten Modul nodes entweder updaten oder speichern.
Bis gestern abend ging das noch einwand frei, habe heute angefangen den code schön zu schreiben, das heißt ich bin ein Harlodri was Variablen angeht, aber wenn es sauber sein soll ...
Also Variablen initialisiert, was aber kaum was damit zu tun haben kann!??? Na ja, seitdem updatet der nicht mehr! Stattdessen erhlate ich nodes mehrfach. Und jetzt kommts:
"Mit identischer nid, vid und timestamp." Ich verstehe nur noch Bahnhof! Weiß da einer was!???
Der Code der für den den content-typ kk-match funktioniert. Heißt der updatet vernünftig wie es soll:
$node = new stdClass();
$node->type = 'kk_match';
node_object_prepare($node);
$node->nid = $nid_kk_match;
//$node->vid = $nid_kk_match;
$node->language = LANGUAGE_NONE;
$node->field_punkte_heimteam ['und']['0']['value']= $punkte_h_temp;
$node->field_punkte_gastteam ['und']['0']['value']= $punkte_g_temp;
$node->field_timestamp_konvertierung['und']['0']['value']='946706400';
Jetzt der alte code von gestern abend, der da noch funktioniert hat:
$node = new stdClass();
$node->type = 'team_value';
node_object_prepare($node);
$node->title = $heimteamnames_tv;
$node->nid = $nid_heimteam_tv;
//$node->vid = $nid_heimteam_tv;
$node->language = LANGUAGE_NONE;
$node->field_tore_heimteam_tv['und']['0']['value']=$heimteam_heimtore_tv_new;
$node->field_tore_heimteam_aktuell_tv['und']['0']['value']=$heimteam_heimtore_aktuell_tv;
$node->field_tore_gastteam_tv['und']['0']['value']=$heimteam_gasttore_tv_new;
$node->field_tore_gastteam_aktuell_tv['und']['0']['value']=$heimteam_gasttore_aktuell_tv;
$node->field_punkte_tv['und']['0']['value'] = $punkte_h_tv_new;
$node->field_punkte_aktuell_tv['und']['0']['value'] = $punkte_h_tv_new;
$path = 'content/results/'.$node->title;
$node->path = array('alias' => $path);
node_save($node);
Und jetzt die Version, mit der ich gehofft habe dass er explizit den zu verändernden node lädt bevor er updatet:
if(!isset($nid_heimteam_tv)){
$node = new stdClass();
$node->type = 'team_value';
node_object_prepare($node);
}
else{
$node = node_load($nid_heimteam_tv);
}
$node->title = $heimteamnames_tv;
//$node->nid = $nid_heimteam_tv;
//$node->vid = $nid_heimteam_tv;
$node->language = LANGUAGE_NONE;
$node->field_tore_heimteam_tv['und']['0']['value']=$heimteam_heimtore_tv_new;
$node->field_tore_heimteam_aktuell_tv['und']['0']['value']=$heimteam_heimtore_aktuell_tv;
$node->field_tore_gastteam_tv['und']['0']['value']=$heimteam_gasttore_tv_new;
$node->field_tore_gastteam_aktuell_tv['und']['0']['value']=$heimteam_gasttore_aktuell_tv;
$node->field_punkte_tv['und']['0']['value'] = $punkte_h_tv_new;
$node->field_punkte_aktuell_tv['und']['0']['value'] = $punkte_h_tv_new;
$path = 'content/results/'.$node->title;
$node->path = array('alias' => $path);
node_save($node);
Wenn ich wenigstens einen Konflikt bekäme dass der node schon existiert! Aber nix da! Hier mal die Ausgaben in Bildern:
3 Mal der identische node! Wie Ihr an den 2 Ausgaben erkennen könnt:
Hast einer eine Idee wie so was passieren kann???
- Anmelden oder Registrieren um Kommentare zu schreiben
Jetzt hab ich mich extra
am 12.10.2013 - 11:57 Uhr
Jetzt hab ich mich extra bemüht auf Englisch zu antworten^^
Machen wir dann lieber mal hier weiter:
Also es kann einfach nicht sein, dass Drupal mehrere Nodes mit der gleichen NID speichert.
Ich habe mir zwar die Tabellenstruktur nicht angesehen, aber nid ist in der Datenbank sicherlich eine unique ID, also ist das speichern mehrerer Nodes der gleichen nid in zwei Ebenen nicht möglich:
1. Drupal verhindert das mit PHP
2. MySQL verhindert es
Wie wird dein Code aufgerufen? Füge mal
<?php
dsm($nid_heimteam_tv);
?>
vor deiner If-Schleife ein und poste was die Ausgabe liefert
Computerboard da wird dir geholfen