Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Blockly
    5. [gelöst] Problem mit Javascript-Funktion in Blockly

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    [gelöst] Problem mit Javascript-Funktion in Blockly

    This topic has been deleted. Only users with topic management privileges can see it.
    • E
      el-lutschi last edited by el-lutschi

      Hallo zusammen,

      ich versuche gerade eine Javascript Funktion in einem Blockly-Funktionsblock zu definieren. Leider lässt sich der Block nicht abspeichern. Es kommt aber auch keine Fehlermeldung. Wenn ich das Script komplett in Javascript schreibe funktioniert alles. Ich würde es aber gerne in Blockly definieren.

      Hier ist das funktionierende Javascript. Kann mir bitte jemand sagen, wie ich es richtig umbauen muss?

      function updateOrInsertBarcode(dbPath, barcode, name) {
          const sqlite3 = require('sqlite3').verbose();
          const db = new sqlite3.Database(dbPath);
      
          db.serialize(() => {
              db.get("SELECT anzahl FROM produkte WHERE barcode = ?", [barcode], (err, row) => {
                  if (err) {
                      console.error('Fehler beim Ausführen der SELECT-Abfrage:', err.message);
                      db.close();
                      return;
                  }
      
                  if (row) {
                      db.run("UPDATE produkte SET anzahl = anzahl + 1 WHERE barcode = ?", [barcode], (err) => {
                          if (err) {
                              console.error('Fehler beim Ausführen der UPDATE-Abfrage:', err.message);
                          } else {
                              console.log(`Anzahl für Barcode ${barcode} wurde um 1 erhöht.`);
                          }
                          db.close();
                      });
                  } else {
                      db.run("INSERT INTO produkte (barcode, name, anzahl) VALUES (?, ?, 1)", [barcode, name], (err) => {
                          if (err) {
                              console.error('Fehler beim Ausführen der INSERT-Abfrage:', err.message);
                          } else {
                              console.log(`Neuer Eintrag für Barcode ${barcode} hinzugefügt.`);
                          }
                          db.close();
                      });
                  }
              });
          });
      }
      
      

      In Blockly will ich dann die 3 Variablen barcode, name, dbPath immer wieder neu definieren können, wenn die Funktion abgerufen wird.

      haus-automatisierung 1 Reply Last reply Reply Quote 0
      • haus-automatisierung
        haus-automatisierung Developer Most Active @el-lutschi last edited by

        @el-lutschi sagte in Problem mit Javascript-Funktion in Blockly:

        Kann mir bitte jemand sagen, wie ich es richtig umbauen muss?

        Du darfst natürlich nur den Inhalt der Funktion in einen Blockly-Baustein kopieren. Also die erste und letzte Zeile weglassen.

        E 1 Reply Last reply Reply Quote 0
        • E
          el-lutschi @haus-automatisierung last edited by

          @haus-automatisierung

          Vielen Dank für die schnelle Hilfe. Das hatte ich zwar bereits erfolglos versucht, aber nachdem ich es nun noch einmal probiert habe funktioniert es. Scheinbar hatte ich beim letzten Versuch doch noch irgendwo einen Fehler. Ich habe es direkt mit weiteren Funktionen getestet. Jetzt läuft alles. Vielen Dank!

          1 Reply Last reply Reply Quote 0
          • First post
            Last post

          Support us

          ioBroker
          Community Adapters
          Donate

          703
          Online

          31.9k
          Users

          80.1k
          Topics

          1.3m
          Posts

          2
          3
          192
          Loading More Posts
          • Oldest to Newest
          • Newest to Oldest
          • Most Votes
          Reply
          • Reply as topic
          Log in to reply
          Community
          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
          The ioBroker Community 2014-2023
          logo