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

node_load/save Speicherproblem

Eingetragen von benny1979 (119)
am 21.06.2010 - 15:36 Uhr in
  • Modul-Entwicklung
  • Drupal 6.x

Hallo,

ich importiere aus einer CSV ungefähr 5.000 Datensätze (einfache, kurze Strings) in einen Inhaltstyp. Ein CSV-Feld enthält eine eindeutige Nummer, die als Primärschlüssel verwendet wird. Leider bekomme ich irgendwann die Fehlermeldung, daß kein weiterer Speicher zur Verfügung steht (Fatal error: Allowed memory size of 134217728 bytes exhausted (tried to allocate 24576 bytes) in C:\Projekte\xampp-php5\htdocs\xyz\sites\all\modules\contrib\cck\theme\content-field.tpl.php on line 49).

Ich frage mich jetzt, warum der Speicher vollläuft. Wie kann ich den Code optimieren?

function getPrimaryKeyNID($id) {
$result = db_query("SELECT nid FROM {content_type_mein_inhaltstyp} WHERE field_primary_key_value='%s'", $id);
         $nid = db_result($result);
         mysql_free_result($result);
         return $nid;
}


while(($data = fgetcsv ($csvDatei, 1000, ",", "'")) !== FALSE ) {
                         $primaryKey = $data[0];
                         $nid = getPrimaryKeyNID($primaryKey);
                         if($nid != FALSE) {
                         // Datensatz existiert bereits => Aktualisieren
                               $node = node_load($nid, NULL, TRUE);
                         }
                         else {
                     $node = new stdClass;
                        $node->type = 'mein_inhaltstyp';
                        $node->created = time();
                        $node->changed = $node->created;
                        $node->status = 1;
                        $node->promote = 1;
                        $node->sticky = 0;
                        $node->uid = 1;          // UID of content owner
                        $node->language = 'de';
                                 $node->field_primary_key[0]['value'] = $data[0];
                         }
                         $node->title = utf8_encode($data[2]);
                         node_save($node);
                         unset($node);
                 }

‹ Tabs im Modul hinzufügen Zugriff auf einzelne Nodes sperren ›
  • Anmelden oder Registrieren um Kommentare zu schreiben

Ich würde die CSV in eine

Eingetragen von Sense (1559)
am 21.06.2010 - 15:44 Uhr

Ich würde die CSV in eine neue Tabelle Deiner DB importieren und von dort aus importieren, anstatt die CSV zu laden, also anstatt:

<?php
while(($data = fgetcsv ($csvDatei, 1000, ",", "'")) !== FALSE ) {
 
// code
}
?>

<?php
$result
= db_query("SELECT * FROM {import}");
while(
$data = db_fetch_array($result)) {
 
// code
}
?>

  • Anmelden oder Registrieren um Kommentare zu schreiben

Hab ich versucht, bringt aber

Eingetragen von benny1979 (119)
am 21.06.2010 - 16:28 Uhr

Hab ich versucht, bringt aber keinerlei Veränderung. Selbst wenn ich in der php.ini das Limit auf 256 MB hochsetze, kommt irgendwann die Fehlermeldung.

Die Funktion, in der die Fehlermeldung erscheint, ist für das Theming der Node zuständig. Das benötige ich aber in dem Fall garnicht. Kann man das deaktivieren?

  • Anmelden oder Registrieren um Kommentare zu schreiben

Tritt der Fehler auch auf,

Eingetragen von naden@drupal.org (36)
am 22.06.2010 - 12:08 Uhr

Tritt der Fehler auch auf, wenn du auf node_load verzichtest?

Nach wie vielen Datensätzen tritt der Fehler auf? Wenn es z.B. immer nach 100 passiert, dann lass das Script einfach 50 mal mit 100 laufen anstatt auf einen Rutsch 5000 zu importieren.

Poste mal dein komplettes Script.

  • Anmelden oder Registrieren um Kommentare zu schreiben

Es tritt auch auf, wenn ich

Eingetragen von benny1979 (119)
am 22.06.2010 - 13:23 Uhr

Es tritt auch auf, wenn ich auf node_load verzichte. Nach 3200 Datensätzen.

Hier wird das Problem auch diskutiert:
http://groups.drupal.org/node/17211

  • Anmelden oder Registrieren um Kommentare zu schreiben

Dann setzt doch ein Limit pro

Eingetragen von Sense (1559)
am 22.06.2010 - 14:15 Uhr

Dann setzt doch ein Limit pro Durchgang von 200 oder so, dann läuft das Script zwar 20mal aber danach hast Du alle Daten komplett importiert.

  • Anmelden oder Registrieren um Kommentare zu schreiben

Genau, wie ich auch schon

Eingetragen von naden@drupal.org (36)
am 22.06.2010 - 14:46 Uhr

Genau, wie ich auch schon geschrieben hatte, ist die Lösung mit dem Limit sicher die einfachste, wenn du das nur einmalig machen musst.

  • Anmelden oder Registrieren um Kommentare zu schreiben

Nur wie giesst man das in

Eingetragen von benny1979 (119)
am 22.06.2010 - 23:06 Uhr

Nur wie giesst man das in Modul-Form, ohne dass der Benutzer davon was mitbekommt?

  • Anmelden oder Registrieren um Kommentare zu schreiben

Benutzeranmeldung

  • Registrieren
  • Neues Passwort anfordern

Aktive Forenthemen

  • Medien und andere Daten mit Feeds von Drupal 7 auf Drupal 10 migrieren
  • 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?
Weiter

Neue Kommentare

  • Inzwischen sind wir bei
    vor 1 Tag 17 Stunden
  • Migrieren von D7 auf D8/ D10/ D11
    vor 2 Tagen 9 Stunden
  • melde mich mal wieder, da ich
    vor 7 Wochen 6 Tagen
  • Hey danke
    vor 8 Wochen 8 Stunden
  • Update: jetzt gibt's ein
    vor 8 Wochen 1 Tag
  • Hallo, im Prinzip habe ich
    vor 8 Wochen 5 Tagen
  • Da scheint die Terminologie
    vor 8 Wochen 5 Tagen
  • Kannst doch auch alles direkt
    vor 9 Wochen 2 Tagen
  • In der entsprechenden View
    vor 9 Wochen 2 Tagen
  • Dazu müsstest Du vermutlich
    vor 9 Wochen 2 Tagen

Statistik

Beiträge im Forum: 250235
Registrierte User: 20462

Neue User:

  • marouane.blel
  • capilclinic
  • Quabzibboter

» 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 19 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