Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. ioBroker Allgemein
    4. Zurücksetzen einzelner Datenpunkte im SQL-Adapter

    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

    Zurücksetzen einzelner Datenpunkte im SQL-Adapter

    This topic has been deleted. Only users with topic management privileges can see it.
    • A
      andi2055 @Scrounger last edited by

      @scrounger

      ich habe dein Script ums Löschen von nicht mehr existierenden Datenpunkten erweitert.
      So konnte ich bei mir über 1Mio überflüssige Datensätze löschen.

      Vielleicht kann es jemand gebrauchen.

      Verwendung auf eigene Gefahr! Vorher Backup anfertigen

      
      async function wartung() {
          try {
      
              const activate_delete = false;
       
              // alle Datenpunkte aus Db holen
              let datapoints = await getQueryResult(`SELECT * FROM iobroker.datapoints`);
              if (datapoints) {
                  let count = 0;
                  let sum = 0;
       
                  // Datenpunkte durchlaufen
                  for (const datapoint of datapoints) {
       
                      // prüfen ob kein Objekt in ioBroker existiert
                      if (!getObject(datapoint.name)) {
                          count++;
       
                          // Daten des Datenpunktes in Tabelle 'ts_bool' zählen
                          let countBool = 0;
                          let booleanTableItems = await getQueryResult(`SELECT * FROM iobroker.ts_bool WHERE id = ${datapoint.id}`);
                          if (booleanTableItems && Object.keys(booleanTableItems).length > 0) {
                              countBool = Object.keys(booleanTableItems).length;
                              if (activate_delete) { 
                                  sendTo('sql.0', 'query', `DELETE FROM iobroker.ts_bool WHERE id = ${datapoint.id}`, function (result) {
                                      if (result.error) {
                                          console.error(result.error);
                                      } else {
                                          // show result
                                          console.log('Rows: ' + JSON.stringify(result.result));
                                      }
                                  });
                              }
                          }
       
                          // Daten des Datenpunktes in Tabelle 'ts_number' zählen
                          let countNumber = 0;
                          let numberTableItems = await getQueryResult(`SELECT * FROM iobroker.ts_number WHERE id = ${datapoint.id}`);
                          if (numberTableItems && Object.keys(numberTableItems).length > 0) {
                              countNumber = Object.keys(numberTableItems).length;
                              if (activate_delete) { 
                                  sendTo('sql.0', 'query', `DELETE FROM iobroker.ts_number WHERE id = ${datapoint.id}`, function (result) {
                                      if (result.error) {
                                          console.error(result.error);
                                      } else {
                                          // show result
                                          console.log('Rows: ' + JSON.stringify(result.result));
                                      }
                                  });
                              }
                          }
       
                          // Daten des Datenpunktes in Tabelle 'ts_string' zählen
                          let countString = 0;
                          let stringTableItems = await getQueryResult(`SELECT * FROM iobroker.ts_string WHERE id = ${datapoint.id}`);
                          if (stringTableItems && Object.keys(stringTableItems).length > 0) {
                              countString = Object.keys(stringTableItems).length;
                              if (activate_delete) { 
                                  sendTo('sql.0', 'query', `DELETE FROM iobroker.ts_string WHERE id = ${datapoint.id}`, function (result) {
                                      if (result.error) {
                                          console.error(result.error);
                                      } else {
                                          // show result
                                          console.log('Rows: ' + JSON.stringify(result.result));
                                      }
                                  });
                              }
                          }
      
                          if (activate_delete) { 
                              sendTo('sql.0', 'query', `DELETE FROM iobroker.datapoints WHERE id = ${datapoint.id}`, function (result) {
                                  if (result.error) {
                                      console.error(result.error);
                                  } else {
                                      // show result
                                      console.log('Rows: ' + JSON.stringify(result.result));
                                  }
                              });
                          }
       
                          console.warn(`DB id: ${datapoint.id} (type: ${datapoint.type}) -> number: ${countNumber}, string: ${countString}, bool: ${countBool} | ioBroker id: '${datapoint.name}'`);
                          sum = sum + countBool + countNumber + countString;
                         
                      }
                  }
                  console.warn(`${count} Objects found, that not exist anymore in ioBroker, sum of items in tables: ${sum.toLocaleString().replace(/,/g, ".")}`);
              }
          } catch (err) {
              console.error(`[wartung] error: ${err.message}`);
              console.error(`[wartung] stack: ${err.stack}`);
          }
      }
       
      async function getQueryResult(query) {
          return new Promise((resolve, reject) => {
              sendTo('sql.0', 'query', query, function (result) {
                  if (!result.error) {
                      resolve(result.result);
                  } else {
                      resolve(null);
                  }
              });
          });
      }
       
      wartung();
      
      
      liv-in-sky B M 3 Replies Last reply Reply Quote 1
      • liv-in-sky
        liv-in-sky @andi2055 last edited by

        @andi2055
        @Scrounger

        danke für die scripte

        ergebnis:

        127 Objects found, that not exist anymore in ioBroker, sum of items in tables: 68.211
        
        1 Reply Last reply Reply Quote 0
        • K
          Kueppert last edited by

          Hallo in die wissende Runde,
          das Skript werde ich vermutlich nicht für InfluxDB verwenden können? Einfach ausprobieren ist mir zu riskant, hab erst 4 Neuaufsätze hinter mir trotz Proxmox ^^
          Vielleicht könnte man eine solche Funktion auch in den jeweiligen Adaptern einbauen? Aber das ist etwas für einen anderen thread...
          Danke euch und vG, Thorsten

          A 1 Reply Last reply Reply Quote 0
          • A
            andi2055 @Kueppert last edited by

            Ich habe solch eine Aufräum-Funktionalität für den SQL-Adapter angefragt.
            https://github.com/ioBroker/ioBroker.sql/issues/247

            Gebt gerne auch dort Feedback, ob ihr so etwas benötigt.
            Mir sparte das beim täglichem Backup der SQL-DB trotz ZIP über 10MB ein.

            5G7K created this issue in ioBroker/ioBroker.sql

            open Cleanup functionality to delete data of not more existing datapoints #247

            1 Reply Last reply Reply Quote 0
            • B
              Borkenkaefer @andi2055 last edited by

              @andi2055 Heyho,

              besten Dank für das Script, ich würde es gerne mal ausprobieren weil ich im Log dauernd die Meldung vom SQL Adapter bekomme, dass Datenpunkt xy keinen Wert zurückgibt. Liegt halt daran, dass es die Datenpunkte nicht mehr gibt 🙂

              Hab das script mal gestartet und es meldet recht schnell Funde, allerdings ist irgendwann Schluss ohne "Abschlussmeldung". Wie lange läuft das denn bei dir so? Hier mittlerweile mehr als eine Stunde ohne weiteres Ergebnis.

              Danke und Gruß
              Andreas

              1 Reply Last reply Reply Quote 0
              • M
                mike2712 @andi2055 last edited by

                @andi2055 hab da mal eine Frage, wo muss dieses Script den ausgeführt werden?

                A 1 Reply Last reply Reply Quote 0
                • A
                  andi2055 @mike2712 last edited by

                  @mike2712
                  als Javascript im JS-Adapter anlegen und ausführen

                  @Borkenkaefer
                  Laufzeit ist abhängig von Anzahl der gefundenen Einträge und Anzahl Datensätze. Wenige Sekunden bis Minuten würde ich sagen. Im Log steht dann genau welche Datenpunkte gefunden wurden und wie viele SQL-Werte dazu noch in der DB stehen

                  M 1 Reply Last reply Reply Quote 1
                  • M
                    mike2712 @andi2055 last edited by mike2712

                    @andi2055
                    Super, danke, wollte da immer schon mal etwas aufräumen, kenne mich im Bereich PHPmyAdmin leider gar nicht aus.
                    Hier ist das Ergebnis von dem Script, was müssten den für ein sinnvolles aufräumen die nächsten Schritte sein?

                    Würde das erweiterte Script von Dir alles überflüssige aus der Datenbank löschen? Wie mache ich den ein Backup so das ich meine archivierten Daten nicht verlieren würde?

                    18:41:55.180	info	javascript.0 (158) Stop script script.js.Allgemein.SQL_TEST
                    18:41:55.183	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 195 (type: 0) -> number: 140294, string: 0, bool: 0 | ioBroker id: 'fritzdect.0.DECT200_116570356042.power'
                    18:41:55.183	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "fritzdect.0.DECT200_087610475216.present" does not exist
                    18:41:55.330	info	javascript.0 (158) Start javascript script.js.Allgemein.SQL_TEST
                    18:41:55.354	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: registered 0 subscriptions, 0 schedules, 0 messages, 0 logs and 0 file subscriptions
                    18:41:55.391	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "hm-rpc.0.MEQ0375275.1.LEVEL" does not exist
                    18:41:56.238	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 34 (type: 0) -> number: 26646, string: 0, bool: 0 | ioBroker id: 'hm-rpc.0.MEQ0375275.1.LEVEL'
                    18:41:56.239	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "sonoff.0.Sonoff-Steckdose-51.POWER" does not exist
                    18:41:56.413	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 77 (type: 2) -> number: 0, string: 0, bool: 4789 | ioBroker id: 'fritzdect.0.DECT200_087610475216.present'
                    18:41:56.414	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "fritzdect.0.DECT200_087610475216.state" does not exist
                    18:41:56.452	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 44 (type: 2) -> number: 0, string: 0, bool: 4953 | ioBroker id: 'sonoff.0.Sonoff-Steckdose-51.POWER'
                    18:41:56.455	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "fritzdect.0.DECT200_116570356042.power" does not exist
                    18:42:02.852	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 195 (type: 0) -> number: 140294, string: 0, bool: 0 | ioBroker id: 'fritzdect.0.DECT200_116570356042.power'
                    18:42:02.853	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "fritzdect.0.DECT200_087610475216.present" does not exist
                    18:42:03.095	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 78 (type: 2) -> number: 0, string: 0, bool: 36314 | ioBroker id: 'fritzdect.0.DECT200_087610475216.state'
                    18:42:03.096	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "fritzdect.0.DECT200_087610475216.power" does not exist
                    18:42:03.223	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 77 (type: 2) -> number: 0, string: 0, bool: 4789 | ioBroker id: 'fritzdect.0.DECT200_087610475216.present'
                    18:42:03.228	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "fritzdect.0.DECT200_087610475216.state" does not exist
                    18:42:06.359	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 78 (type: 2) -> number: 0, string: 0, bool: 36314 | ioBroker id: 'fritzdect.0.DECT200_087610475216.state'
                    18:42:06.360	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "fritzdect.0.DECT200_087610475216.power" does not exist
                    18:42:24.748	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 79 (type: 0) -> number: 270994, string: 0, bool: 0 | ioBroker id: 'fritzdect.0.DECT200_087610475216.power'
                    18:42:24.749	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "fritzdect.0.DECT200_087610475216.temp" does not exist
                    18:42:25.869	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 79 (type: 0) -> number: 270994, string: 0, bool: 0 | ioBroker id: 'fritzdect.0.DECT200_087610475216.power'
                    18:42:25.870	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "fritzdect.0.DECT200_087610475216.temp" does not exist
                    18:42:27.476	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 80 (type: 0) -> number: 30132, string: 0, bool: 0 | ioBroker id: 'fritzdect.0.DECT200_087610475216.temp'
                    18:42:27.477	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "fritzdect.0.DECT200_116300020276.temp" does not exist
                    18:42:27.667	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 80 (type: 0) -> number: 30132, string: 0, bool: 0 | ioBroker id: 'fritzdect.0.DECT200_087610475216.temp'
                    18:42:27.668	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "fritzdect.0.DECT200_116300020276.temp" does not exist
                    18:42:29.786	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 90 (type: 0) -> number: 39412, string: 0, bool: 0 | ioBroker id: 'fritzdect.0.DECT200_116300020276.temp'
                    18:42:29.788	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "tradfri.0.L-65537.lightbulb.state" does not exist
                    18:42:29.975	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 90 (type: 0) -> number: 39412, string: 0, bool: 0 | ioBroker id: 'fritzdect.0.DECT200_116300020276.temp'
                    18:42:29.976	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "tradfri.0.L-65537.lightbulb.state" does not exist
                    18:42:30.358	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 102 (type: 2) -> number: 0, string: 0, bool: 2178 | ioBroker id: 'tradfri.0.L-65537.lightbulb.state'
                    18:42:30.358	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "tradfri.0.L-65539.lightbulb.state" does not exist
                    18:42:30.369	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 102 (type: 2) -> number: 0, string: 0, bool: 2178 | ioBroker id: 'tradfri.0.L-65537.lightbulb.state'
                    18:42:30.370	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "tradfri.0.L-65539.lightbulb.state" does not exist
                    18:42:30.593	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 103 (type: 2) -> number: 0, string: 0, bool: 2177 | ioBroker id: 'tradfri.0.L-65539.lightbulb.state'
                    18:42:30.594	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "tradfri.0.G-131073.state" does not exist
                    18:42:30.615	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 103 (type: 2) -> number: 0, string: 0, bool: 2177 | ioBroker id: 'tradfri.0.L-65539.lightbulb.state'
                    18:42:30.616	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "tradfri.0.G-131073.state" does not exist
                    18:42:30.741	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 104 (type: 2) -> number: 0, string: 0, bool: 2246 | ioBroker id: 'tradfri.0.G-131073.state'
                    18:42:30.742	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "tradfri.0.L-65541.lightbulb.state" does not exist
                    18:42:30.760	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 104 (type: 2) -> number: 0, string: 0, bool: 2246 | ioBroker id: 'tradfri.0.G-131073.state'
                    18:42:30.761	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "tradfri.0.L-65541.lightbulb.state" does not exist
                    18:42:30.930	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 105 (type: 2) -> number: 0, string: 0, bool: 2176 | ioBroker id: 'tradfri.0.L-65541.lightbulb.state'
                    18:42:30.931	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "tradfri.0.G-131074.state" does not exist
                    18:42:30.934	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 105 (type: 2) -> number: 0, string: 0, bool: 2176 | ioBroker id: 'tradfri.0.L-65541.lightbulb.state'
                    18:42:30.935	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "tradfri.0.G-131074.state" does not exist
                    18:42:31.119	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 106 (type: 2) -> number: 0, string: 0, bool: 2248 | ioBroker id: 'tradfri.0.G-131074.state'
                    18:42:31.122	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "tradfri.0.G-131075.state" does not exist
                    18:42:31.138	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 106 (type: 2) -> number: 0, string: 0, bool: 2248 | ioBroker id: 'tradfri.0.G-131074.state'
                    18:42:31.138	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "tradfri.0.G-131075.state" does not exist
                    18:42:31.402	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 107 (type: 2) -> number: 0, string: 0, bool: 2167 | ioBroker id: 'tradfri.0.G-131075.state'
                    18:42:31.403	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "MeineObjekte.0.Allgemein.Handy_Anwesend" does not exist
                    18:42:31.410	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 107 (type: 2) -> number: 0, string: 0, bool: 2167 | ioBroker id: 'tradfri.0.G-131075.state'
                    18:42:31.412	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "MeineObjekte.0.Allgemein.Handy_Anwesend" does not exist
                    18:42:31.936	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 110 (type: 2) -> number: 0, string: 0, bool: 4795 | ioBroker id: 'MeineObjekte.0.Allgemein.Handy_Anwesend'
                    18:42:31.937	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "fritzdect.0.DECT200_116300011906.state" does not exist
                    18:42:31.975	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 110 (type: 2) -> number: 0, string: 0, bool: 4795 | ioBroker id: 'MeineObjekte.0.Allgemein.Handy_Anwesend'
                    18:42:31.976	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "fritzdect.0.DECT200_116300011906.state" does not exist
                    18:42:34.222	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 112 (type: 2) -> number: 0, string: 0, bool: 33197 | ioBroker id: 'fritzdect.0.DECT200_116300011906.state'
                    18:42:34.222	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "fritzdect.0.DECT200_116300011906.power" does not exist
                    18:42:34.236	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 112 (type: 2) -> number: 0, string: 0, bool: 33197 | ioBroker id: 'fritzdect.0.DECT200_116300011906.state'
                    18:42:34.237	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "fritzdect.0.DECT200_116300011906.power" does not exist
                    18:43:04.825	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 113 (type: 0) -> number: 350196, string: 0, bool: 0 | ioBroker id: 'fritzdect.0.DECT200_116300011906.power'
                    18:43:04.827	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "MeineObjekte.0.Tanel.Internet.Berechnung.Zeit_Soll_MM" does not exist
                    18:43:05.480	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 113 (type: 0) -> number: 350196, string: 0, bool: 0 | ioBroker id: 'fritzdect.0.DECT200_116300011906.power'
                    18:43:05.480	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "MeineObjekte.0.Tanel.Internet.Berechnung.Zeit_Soll_MM" does not exist
                    18:43:05.635	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 187 (type: 1) -> number: 4, string: 1, bool: 0 | ioBroker id: 'MeineObjekte.0.Tanel.Internet.Berechnung.Zeit_Soll_MM'
                    18:43:05.636	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "fritzdect.0.DECT200_116300020276.state" does not exist
                    18:43:05.789	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 187 (type: 1) -> number: 4, string: 1, bool: 0 | ioBroker id: 'MeineObjekte.0.Tanel.Internet.Berechnung.Zeit_Soll_MM'
                    18:43:05.789	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "fritzdect.0.DECT200_116300020276.state" does not exist
                    18:43:08.464	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 116 (type: 2) -> number: 0, string: 0, bool: 33178 | ioBroker id: 'fritzdect.0.DECT200_116300020276.state'
                    18:43:08.465	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "fritzdect.0.DECT200_116300020276.power" does not exist
                    18:43:08.520	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 116 (type: 2) -> number: 0, string: 0, bool: 33178 | ioBroker id: 'fritzdect.0.DECT200_116300020276.state'
                    18:43:08.520	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "fritzdect.0.DECT200_116300020276.power" does not exist
                    18:44:05.666	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 117 (type: 0) -> number: 496674, string: 0, bool: 0 | ioBroker id: 'fritzdect.0.DECT200_116300020276.power'
                    18:44:05.668	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "tr-064.0.devices.Sonoff-Steckdose-51" does not exist
                    18:44:07.549	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 117 (type: 0) -> number: 496674, string: 0, bool: 0 | ioBroker id: 'fritzdect.0.DECT200_116300020276.power'
                    18:44:07.550	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "tr-064.0.devices.Sonoff-Steckdose-51" does not exist
                    18:44:07.989	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 123 (type: 2) -> number: 0, string: 0, bool: 4765 | ioBroker id: 'tr-064.0.devices.Sonoff-Steckdose-51'
                    18:44:07.990	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "tr-064.0.devices.Home-Echo-Dot-Arbeitszimmer" does not exist
                    18:44:08.261	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 123 (type: 2) -> number: 0, string: 0, bool: 4765 | ioBroker id: 'tr-064.0.devices.Sonoff-Steckdose-51'
                    18:44:08.261	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "tr-064.0.devices.Home-Echo-Dot-Arbeitszimmer" does not exist
                    18:44:08.440	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 128 (type: 2) -> number: 0, string: 0, bool: 1685 | ioBroker id: 'tr-064.0.devices.Home-Echo-Dot-Arbeitszimmer'
                    18:44:08.441	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "MeineObjekte.0.Counter.PC-Tanel.Count-24h" does not exist
                    18:44:08.458	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 128 (type: 2) -> number: 0, string: 0, bool: 1685 | ioBroker id: 'tr-064.0.devices.Home-Echo-Dot-Arbeitszimmer'
                    18:44:08.459	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "MeineObjekte.0.Counter.PC-Tanel.Count-24h" does not exist
                    18:44:08.495	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 181 (type: 1) -> number: 0, string: 5, bool: 0 | ioBroker id: 'MeineObjekte.0.Counter.PC-Tanel.Count-24h'
                    18:44:08.496	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "MeineObjekte.0.Counter.PC-Tanel.IP-Count-24h" does not exist
                    18:44:08.508	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 181 (type: 1) -> number: 0, string: 5, bool: 0 | ioBroker id: 'MeineObjekte.0.Counter.PC-Tanel.Count-24h'
                    18:44:08.509	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "MeineObjekte.0.Counter.PC-Tanel.IP-Count-24h" does not exist
                    18:44:08.573	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 182 (type: 1) -> number: 0, string: 5, bool: 0 | ioBroker id: 'MeineObjekte.0.Counter.PC-Tanel.IP-Count-24h'
                    18:44:08.574	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "MeineObjekte.0.Tanel.Internet.Nutzung" does not exist
                    18:44:08.615	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 182 (type: 1) -> number: 0, string: 5, bool: 0 | ioBroker id: 'MeineObjekte.0.Counter.PC-Tanel.IP-Count-24h'
                    18:44:08.616	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "MeineObjekte.0.Tanel.Internet.Nutzung" does not exist
                    18:44:08.675	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 188 (type: 1) -> number: 0, string: 1, bool: 4 | ioBroker id: 'MeineObjekte.0.Tanel.Internet.Nutzung'
                    18:44:08.675	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "hm-rega.0.2115" does not exist
                    18:44:08.696	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 188 (type: 1) -> number: 0, string: 1, bool: 4 | ioBroker id: 'MeineObjekte.0.Tanel.Internet.Nutzung'
                    18:44:08.696	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "hm-rega.0.2115" does not exist
                    18:44:10.044	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 189 (type: 2) -> number: 0, string: 0, bool: 20869 | ioBroker id: 'hm-rega.0.2115'
                    18:44:10.045	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "tr-064.0.devices.Home-Echo-Dot-Kueche" does not exist
                    18:44:10.066	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 189 (type: 2) -> number: 0, string: 0, bool: 20869 | ioBroker id: 'hm-rega.0.2115'
                    18:44:10.067	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "tr-064.0.devices.Home-Echo-Dot-Kueche" does not exist
                    18:44:10.671	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 138 (type: 2) -> number: 0, string: 0, bool: 4753 | ioBroker id: 'tr-064.0.devices.Home-Echo-Dot-Kueche'
                    18:44:10.672	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "tr-064.0.devices.Home-Fritz-Repeater-5GHZ" does not exist
                    18:44:10.674	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 138 (type: 2) -> number: 0, string: 0, bool: 4753 | ioBroker id: 'tr-064.0.devices.Home-Echo-Dot-Kueche'
                    18:44:10.674	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "tr-064.0.devices.Home-Fritz-Repeater-5GHZ" does not exist
                    18:44:11.037	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 140 (type: 2) -> number: 0, string: 0, bool: 4738 | ioBroker id: 'tr-064.0.devices.Home-Fritz-Repeater-5GHZ'
                    18:44:11.038	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "tr-064.0.devices.Home-HP-LaserJet" does not exist
                    18:44:11.052	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 140 (type: 2) -> number: 0, string: 0, bool: 4738 | ioBroker id: 'tr-064.0.devices.Home-Fritz-Repeater-5GHZ'
                    18:44:11.053	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "tr-064.0.devices.Home-HP-LaserJet" does not exist
                    18:44:11.287	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 146 (type: 2) -> number: 0, string: 0, bool: 4782 | ioBroker id: 'tr-064.0.devices.Home-HP-LaserJet'
                    18:44:11.289	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "tr-064.0.devices.Home-HP-LaserJet-LAN" does not exist
                    18:44:11.308	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 146 (type: 2) -> number: 0, string: 0, bool: 4782 | ioBroker id: 'tr-064.0.devices.Home-HP-LaserJet'
                    18:44:11.310	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "tr-064.0.devices.Home-HP-LaserJet-LAN" does not exist
                    18:44:11.599	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 147 (type: 2) -> number: 0, string: 0, bool: 4778 | ioBroker id: 'tr-064.0.devices.Home-HP-LaserJet-LAN'
                    18:44:11.600	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "tr-064.0.devices.Home-TV-Schlafzimmer-SAT" does not exist
                    18:44:11.605	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 147 (type: 2) -> number: 0, string: 0, bool: 4778 | ioBroker id: 'tr-064.0.devices.Home-HP-LaserJet-LAN'
                    18:44:11.605	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "tr-064.0.devices.Home-TV-Schlafzimmer-SAT" does not exist
                    18:44:11.771	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 148 (type: 2) -> number: 0, string: 0, bool: 1617 | ioBroker id: 'tr-064.0.devices.Home-TV-Schlafzimmer-SAT'
                    18:44:11.778	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "hm-rpc.2.0008D8A9AC1C5B.4.LEVEL" does not exist
                    18:44:11.800	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 148 (type: 2) -> number: 0, string: 0, bool: 1617 | ioBroker id: 'tr-064.0.devices.Home-TV-Schlafzimmer-SAT'
                    18:44:11.800	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "hm-rpc.2.0008D8A9AC1C5B.4.LEVEL" does not exist
                    18:44:11.953	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 149 (type: 0) -> number: 831, string: 0, bool: 0 | ioBroker id: 'hm-rpc.2.0008D8A9AC1C5B.4.LEVEL'
                    18:44:11.954	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "hm-rpc.2.0008D8A9AC1B2A.4.LEVEL" does not exist
                    18:44:11.955	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 149 (type: 0) -> number: 831, string: 0, bool: 0 | ioBroker id: 'hm-rpc.2.0008D8A9AC1C5B.4.LEVEL'
                    18:44:11.957	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "hm-rpc.2.0008D8A9AC1B2A.4.LEVEL" does not exist
                    18:44:12.110	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 150 (type: 0) -> number: 1170, string: 0, bool: 0 | ioBroker id: 'hm-rpc.2.0008D8A9AC1B2A.4.LEVEL'
                    18:44:12.111	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "hm-rpc.2.000855699C43AF.4.STATE" does not exist
                    18:44:12.113	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 150 (type: 0) -> number: 1170, string: 0, bool: 0 | ioBroker id: 'hm-rpc.2.0008D8A9AC1B2A.4.LEVEL'
                    18:44:12.114	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "hm-rpc.2.000855699C43AF.4.STATE" does not exist
                    18:44:12.268	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 151 (type: 2) -> number: 0, string: 0, bool: 775 | ioBroker id: 'hm-rpc.2.000855699C43AF.4.STATE'
                    18:44:12.272	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "tr-064.0.devices.Home-iPadMini" does not exist
                    18:44:12.275	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 151 (type: 2) -> number: 0, string: 0, bool: 775 | ioBroker id: 'hm-rpc.2.000855699C43AF.4.STATE'
                    18:44:12.279	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "tr-064.0.devices.Home-iPadMini" does not exist
                    18:44:12.511	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 153 (type: 2) -> number: 0, string: 0, bool: 1705 | ioBroker id: 'tr-064.0.devices.Home-iPadMini'
                    18:44:12.512	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "tr-064.0.devices.Mike-iPhone-7plus" does not exist
                    18:44:12.560	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 153 (type: 2) -> number: 0, string: 0, bool: 1705 | ioBroker id: 'tr-064.0.devices.Home-iPadMini'
                    18:44:12.561	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "tr-064.0.devices.Mike-iPhone-7plus" does not exist
                    18:44:14.010	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 155 (type: 2) -> number: 0, string: 0, bool: 27568 | ioBroker id: 'tr-064.0.devices.Mike-iPhone-7plus'
                    18:44:14.011	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "fritzdect.0.DECT200_116570356042.state" does not exist
                    18:44:14.028	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 155 (type: 2) -> number: 0, string: 0, bool: 27568 | ioBroker id: 'tr-064.0.devices.Mike-iPhone-7plus'
                    18:44:14.029	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "fritzdect.0.DECT200_116570356042.state" does not exist
                    18:44:14.814	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 196 (type: 2) -> number: 0, string: 0, bool: 15562 | ioBroker id: 'fritzdect.0.DECT200_116570356042.state'
                    18:44:14.814	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "tr-064.0.devices.Home-ioBroker" does not exist
                    18:44:14.839	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 196 (type: 2) -> number: 0, string: 0, bool: 15562 | ioBroker id: 'fritzdect.0.DECT200_116570356042.state'
                    18:44:14.840	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "tr-064.0.devices.Home-ioBroker" does not exist
                    18:44:15.405	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 158 (type: 2) -> number: 0, string: 0, bool: 4734 | ioBroker id: 'tr-064.0.devices.Home-ioBroker'
                    18:44:15.406	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "FRITZ!DECT 200 #2.power" does not exist
                    18:44:15.441	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 158 (type: 2) -> number: 0, string: 0, bool: 4734 | ioBroker id: 'tr-064.0.devices.Home-ioBroker'
                    18:44:15.449	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "FRITZ!DECT 200 #2.power" does not exist
                    18:44:15.582	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 197 (type: 0) -> number: 4, string: 0, bool: 0 | ioBroker id: 'FRITZ!DECT 200 #2.power'
                    18:44:15.583	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "FRITZ!DECT 200 #2.power.state" does not exist
                    18:44:15.584	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 197 (type: 0) -> number: 4, string: 0, bool: 0 | ioBroker id: 'FRITZ!DECT 200 #2.power'
                    18:44:15.585	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "FRITZ!DECT 200 #2.power.state" does not exist
                    18:44:15.703	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 198 (type: 1) -> number: 0, string: 1, bool: 0 | ioBroker id: 'FRITZ!DECT 200 #2.power.state'
                    18:44:15.704	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "FRITZ!DECT 200 #2.state" does not exist
                    18:44:15.740	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 198 (type: 1) -> number: 0, string: 1, bool: 0 | ioBroker id: 'FRITZ!DECT 200 #2.power.state'
                    18:44:15.741	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "FRITZ!DECT 200 #2.state" does not exist
                    18:44:15.830	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 199 (type: 2) -> number: 0, string: 0, bool: 15 | ioBroker id: 'FRITZ!DECT 200 #2.state'
                    18:44:15.849	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "envertech-pv.0.data.gateway_90013936.11150211.POWER" does not exist
                    18:44:15.898	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 199 (type: 2) -> number: 0, string: 0, bool: 15 | ioBroker id: 'FRITZ!DECT 200 #2.state'
                    18:44:15.912	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "envertech-pv.0.data.gateway_90013936.11150211.POWER" does not exist
                    18:44:16.090	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 247 (type: 1) -> number: 0, string: 1039, bool: 0 | ioBroker id: 'envertech-pv.0.data.gateway_90013936.11150211.POWER'
                    18:44:16.091	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "envertech-pv.0.data.gateway_90013936.11150603.POWER" does not exist
                    18:44:16.127	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 247 (type: 1) -> number: 0, string: 1039, bool: 0 | ioBroker id: 'envertech-pv.0.data.gateway_90013936.11150211.POWER'
                    18:44:16.128	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "envertech-pv.0.data.gateway_90013936.11150603.POWER" does not exist
                    18:44:16.311	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 248 (type: 1) -> number: 0, string: 1045, bool: 0 | ioBroker id: 'envertech-pv.0.data.gateway_90013936.11150603.POWER'
                    18:44:16.312	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "0_userdata.0.kW_Gesamt" does not exist
                    18:44:16.349	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 248 (type: 1) -> number: 0, string: 1045, bool: 0 | ioBroker id: 'envertech-pv.0.data.gateway_90013936.11150603.POWER'
                    18:44:16.349	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "0_userdata.0.kW_Gesamt" does not exist
                    18:44:18.926	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 250 (type: 0) -> number: 41422, string: 0, bool: 0 | ioBroker id: '0_userdata.0.kW_Gesamt'
                    18:44:18.936	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "envertech-pv.0.data.gateway_90013936.260W-Süd-1.POWER" does not exist
                    18:44:19.066	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 250 (type: 0) -> number: 41422, string: 0, bool: 0 | ioBroker id: '0_userdata.0.kW_Gesamt'
                    18:44:19.066	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: Object "envertech-pv.0.data.gateway_90013936.260W-Süd-1.POWER" does not exist
                    18:44:21.690	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 255 (type: 1) -> number: 0, string: 57947, bool: 0 | ioBroker id: 'envertech-pv.0.data.gateway_90013936.260W-Süd-1.POWER'
                    18:44:21.712	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: 45 Objects found, that not exist anymore in ioBroker, sum of items in tables: 1.686.591
                    18:44:22.548	info	javascript.0 (158) script.js.Allgemein.SQL_TEST: DB id: 255 (type: 1) -> number: 0, string: 57947, bool: 0 | ioBroker id: 'envertech-pv.0.data.gateway_90013936.260W-Süd-1.POWER'
                    18:44:22.550	warn	javascript.0 (158) script.js.Allgemein.SQL_TEST: 45 Objects found, that not exist anymore in ioBroker, sum of items in tables: 1.686.591
                    
                    A 1 Reply Last reply Reply Quote 0
                    • A
                      andi2055 @mike2712 last edited by

                      @mike2712
                      wenn du so wenig Kenntnisse hast, dann würde ich ganz ehrlich raten auf das Löschen zu verzichten.
                      Besser die paar unnötigen Daten als dass etwas schief läuft...
                      Zum Löschen musst du im Skript die Konstante auf true setzen. Alles auf eigene Gefahr!

                      Für Backup kannst du auch ioBroker backup Adapter verwenden

                      M 1 Reply Last reply Reply Quote 0
                      • M
                        mike2712 @andi2055 last edited by

                        @andi2055 Danke, ja iobroker backup ist selbstverständlich vorhanden, es geht mir um die noch gültigen Einträge in der Datenbank (diese werden mit dem Adapter ja nicht gesichert), da habe ich kein Plan, ich wüsste auch nicht einmal wie ich es richtig händisch löschen müsste in der Datenbank, ich sehe die Datenpunkte, wenn ich einen Datenpunkt lösche, werden dann alle Daten zu diesem Datenpunkt gelöscht, aber händisch ist das sicher wie das aussieht auch sehr mühselig.
                        Was kann passieren wenn es mit dem scipt schief geht? Das ich die Daten verliere die in der Datenbank stehen, kann man in der Datenbank selbst ein komplette Update machen, habe versucht die Daten zu exportieren, aber das dauert ewig.

                        1 Reply Last reply Reply Quote 0
                        • BananaJoe
                          BananaJoe Most Active last edited by

                          @andi2055 sagte in Zurücksetzen einzelner Datenpunkte im SQL-Adapter:

                          ich habe dein Script ums Löschen von nicht mehr existierenden Datenpunkten erweitert.
                          So konnte ich bei mir über 1Mio überflüssige Datensätze löschen.
                          Vielleicht kann es jemand gebrauchen.
                          Verwendung auf eigene Gefahr! Vorher Backup anfertigen

                          Öhm, Sehe ich das richtig das das Skript nur Daten von nicht mehr existierenden Datenpunkten löscht?
                          Ich würde auch gerne Datenpunkte löschen bei denen die SQL-Protokollierung deaktiviert wurde.

                          Ich fang schon mal an zu suchen wie man das ermitteln kann ...

                          1 Reply Last reply Reply Quote 0
                          • BananaJoe
                            BananaJoe Most Active last edited by BananaJoe

                            Und ich Antworte mir selbst:
                            Hier ist die Version die danach geht ob die Protokollierung per SQL aktiv ist.
                            Ist diese nicht (mehr) aktiv so taucht diese als zu löschen auf.
                            Gelöscht wird wie bisher auch wenn oben
                            const activate_delete = false; auf true gesetzt wird

                            Benutzen auf eigene Gefahr, Verbesserungsvorschläge Willkommen. Eventuell braucht das Skript langsam mal eine Versionierung Habe mal einen kleinen Header dazu gesetzt mit den Änderungen

                            // SQL_Delete_Dead_Objects
                            // V0.3
                            //
                            // Changelog:
                            // ----------
                            // 10.08.2019 V0.1   Scrounger   erste Version welche nicht mehr existierende Datenpunkte anzeigt           https://forum.iobroker.net/post/289821
                            // 03.05.2022 V0.2   andi2055    erweitert das die Daten auch aus der Datenbank gelöscht werden             https://forum.iobroker.net/post/798291
                            // 01.02.2023 V0.3   BananaJoe   umgestellt das nun Datenpunkte ohne SQL-Protokollierung gefunden werden    https://forum.iobroker.net/post/939101
                            
                            
                            async function wartung() {
                                try {
                             
                                    // Hier das löschen einschalten! Sonst nur Trocken-Test
                                    const activate_delete = false;
                            
                            
                                    // Alle Datenpunkte holen bei welchen die SQL-Protokollierung aktiv ist:
                                    let datapointsActiveArray = new Array();
                                    let datapointsActiceStrings = "";
                                    await sendTo('sql.0', 'getEnabledDPs', {}, function (result) {
                                        Object.entries(result).forEach((entry) => {
                                            const [key, value] = entry;
                                            // console.log(`${key}`);
                                            datapointsActiceStrings = datapointsActiceStrings + `${key}` + ";";
                                            });
                                        //console.log(datapointsActiceStrings);
                                        datapointsActiveArray = datapointsActiceStrings.split(';');
                                    });
                                    
                                    // alle Datenpunkte aus Db holen
                                    let datapoints = await getQueryResult(`SELECT * FROM iobroker.datapoints`);
                                    if (datapoints) {
                                        let count = 0;
                                        let sum = 0;
                             
                                        // Datenpunkte durchlaufen
                                        for (const datapoint of datapoints) {
                                             // prüfen ob kein Objekt in ioBroker existiert
                                            // if (!getObject(datapoint.name)) {
                            
                                            // prüfen ob SQL-Protokollierung nicht aktiv ist
                                            if (!datapointsActiveArray.includes(datapoint.name)) {
                                                count++;
                             
                                                // Daten des Datenpunktes in Tabelle 'ts_bool' zählen
                                                let countBool = 0;
                                                let booleanTableItems = await getQueryResult(`SELECT * FROM iobroker.ts_bool WHERE id = ${datapoint.id}`);
                                                if (booleanTableItems && Object.keys(booleanTableItems).length > 0) {
                                                    countBool = Object.keys(booleanTableItems).length;
                                                    if (activate_delete) { 
                                                        sendTo('sql.0', 'query', `DELETE FROM iobroker.ts_bool WHERE id = ${datapoint.id}`, function (result) {
                                                            if (result.error) {
                                                                console.error(result.error);
                                                            } else {
                                                                // show result
                                                                console.log('Rows: ' + JSON.stringify(result.result));
                                                            }
                                                        });
                                                    }
                                                }
                             
                                                // Daten des Datenpunktes in Tabelle 'ts_number' zählen
                                                let countNumber = 0;
                                                let numberTableItems = await getQueryResult(`SELECT * FROM iobroker.ts_number WHERE id = ${datapoint.id}`);
                                                if (numberTableItems && Object.keys(numberTableItems).length > 0) {
                                                    countNumber = Object.keys(numberTableItems).length;
                                                    if (activate_delete) { 
                                                        sendTo('sql.0', 'query', `DELETE FROM iobroker.ts_number WHERE id = ${datapoint.id}`, function (result) {
                                                            if (result.error) {
                                                                console.error(result.error);
                                                            } else {
                                                                // show result
                                                                console.log('Rows: ' + JSON.stringify(result.result));
                                                            }
                                                        });
                                                    }
                                                }
                             
                                                // Daten des Datenpunktes in Tabelle 'ts_string' zählen
                                                let countString = 0;
                                                let stringTableItems = await getQueryResult(`SELECT * FROM iobroker.ts_string WHERE id = ${datapoint.id}`);
                                                if (stringTableItems && Object.keys(stringTableItems).length > 0) {
                                                    countString = Object.keys(stringTableItems).length;
                                                    if (activate_delete) { 
                                                        sendTo('sql.0', 'query', `DELETE FROM iobroker.ts_string WHERE id = ${datapoint.id}`, function (result) {
                                                            if (result.error) {
                                                                console.error(result.error);
                                                            } else {
                                                                // show result
                                                                console.log('Rows: ' + JSON.stringify(result.result));
                                                            }
                                                        });
                                                    }
                                                }
                             
                                                if (activate_delete) { 
                                                    sendTo('sql.0', 'query', `DELETE FROM iobroker.datapoints WHERE id = ${datapoint.id}`, function (result) {
                                                        if (result.error) {
                                                            console.error(result.error);
                                                        } else {
                                                            // show result
                                                            console.log('Rows: ' + JSON.stringify(result.result));
                                                        }
                                                    });
                                                }
                             
                                                console.warn(`DB id: ${datapoint.id} (type: ${datapoint.type}) -> number: ${countNumber}, string: ${countString}, bool: ${countBool} | ioBroker id: '${datapoint.name}'`);
                                                sum = sum + countBool + countNumber + countString;
                                               
                                            }
                                        }
                                        console.warn(`${count} Objects found, that not exist anymore in ioBroker, sum of items in tables: ${sum.toLocaleString().replace(/,/g, ".")}`);
                                    }
                                } catch (err) {
                                    console.error(`[wartung] error: ${err.message}`);
                                    console.error(`[wartung] stack: ${err.stack}`);
                                }
                            }
                             
                            async function getQueryResult(query) {
                                return new Promise((resolve, reject) => {
                                    sendTo('sql.0', 'query', query, function (result) {
                                        if (!result.error) {
                                            resolve(result.result);
                                        } else {
                                            resolve(null);
                                        }
                                    });
                                });
                            }
                             
                            wartung();
                            
                            1 Reply Last reply Reply Quote 1
                            • bahnuhr
                              bahnuhr Forum Testing Most Active last edited by

                              @bananajoe
                              Habe das Script als js eingefügt und gestartet.
                              Es tut sich gar nichts; absolut nichts im log.

                              Muss man da irgendwas beachten ?

                              BananaJoe 1 Reply Last reply Reply Quote 0
                              • BananaJoe
                                BananaJoe Most Active @bahnuhr last edited by BananaJoe

                                @bahnuhr also nicht mal einen Fehler oder so?
                                da sollte unten doch stehen das er das Skript gestartet hat - und dann kommt nichts?
                                Die Zusammenfassung sollte auf jeden Fall kommen (und wenn die 0 ist).

                                Sind Log-Ausgaben als Warnung.

                                8532a54e-9bf6-4657-bb23-067f7c007dcc-image.png

                                bahnuhr 1 Reply Last reply Reply Quote 0
                                • bahnuhr
                                  bahnuhr Forum Testing Most Active last edited by

                                  @bananajoe

                                  Wenn ich das Script starte kommt unten im log:
                                  6c4b21ef-ce37-45f7-89d3-81254e78db29-image.png

                                  Sonst nix.

                                  manches ist auch rot unterstrichen:
                                  a7c74bbe-dc3b-4854-9d25-4446997dfbac-image.png

                                  850d2054-ae7f-40ab-b230-a58c92b7d344-image.png

                                  komisch

                                  1 Reply Last reply Reply Quote 0
                                  • bahnuhr
                                    bahnuhr Forum Testing Most Active @BananaJoe last edited by

                                    @bananajoe
                                    Und bei sql ist folgendes in der config:
                                    d0000acf-1fe9-45e4-acd4-43edc0f3a9bd-image.png

                                    BananaJoe 1 Reply Last reply Reply Quote 0
                                    • BananaJoe
                                      BananaJoe Most Active @bahnuhr last edited by BananaJoe

                                      @bahnuhr wie heisst denn deine Instanz? sql.0 ? Laut deinem Screehshot schon.
                                      Das steht nämlich so fest verdrahtet im Skript. (noch)
                                      Mit SQLite habe ich das auch nicht getestet, spricht aber eigentlich nichts dagegen das es funktionieren sollte.

                                      sonst nimm mal in Zeile 23 die // vorne weg, dann müsste er die im Log unten die ganzen Datenpunkte auflisten

                                      Nachtrag: Die letzte Zeile hast du mit kopiert, oder?

                                      wartung();
                                      

                                      Die ruft die Funktion ja erst auf

                                      bahnuhr 2 Replies Last reply Reply Quote 0
                                      • bahnuhr
                                        bahnuhr Forum Testing Most Active @BananaJoe last edited by

                                        @bananajoe sagte in Zurücksetzen einzelner Datenpunkte im SQL-Adapter:

                                        sql.0 ?

                                        c75e9189-c703-4922-b606-b7b2cb5f2102-image.png

                                        @bananajoe sagte in Zurücksetzen einzelner Datenpunkte im SQL-Adapter:

                                        Zeile 23 die //

                                        Hatte ich schon; alle DP werden im log aufgelistet.
                                        Es kommen da schon ca. 100 (nicht gezählt)

                                        @bananajoe sagte in Zurücksetzen einzelner Datenpunkte im SQL-Adapter:

                                        Nachtrag: Die letzte Zeile hast du mit kopiert, oder?

                                        Na sicher, Script startet ja auch.
                                        Und die DP werden im log wenn Zeile 23 aktiv auch aufgelistet.
                                        Und wenn Zeile 26 (auc log) aktiv ist, das funktioniert auch.

                                        Ich glaube es liegt an dieser Zuweisung:

                                               let datapoints = await getQueryResult(`SELECT * FROM iobroker.datapoints`);
                                        

                                        Das scheint nicht zu klappen

                                        1 Reply Last reply Reply Quote 0
                                        • bahnuhr
                                          bahnuhr Forum Testing Most Active @BananaJoe last edited by

                                          @bananajoe

                                          so ich habs:

                                          Die Zeile 31 läuft nicht:
                                          falsch ist:
                                          let datapoints = await getQueryResult(SELECT * FROM iobroker.datapoints);

                                          richtig ist:
                                          let datapoints = await getQueryResult(SELECT * FROM datapoints);

                                          Jetzt kommt bei mir im log auch sowas:

                                          javascript.0
                                          2023-02-01 21:12:53.124	warn	script.js.Scripte.test9: 15 Objects found, that not exist anymore in ioBroker, sum of items in tables: 0
                                          
                                          javascript.0
                                          2023-02-01 21:12:53.104	warn	script.js.Scripte.test9: DB id: 280 (type: 0) -> number: 0, string: 0, bool: 0 | ioBroker id: 'hm-rpc.0.OEQ2092890.4.ACTUAL_TEMPERATURE'
                                          
                                          javascript.0
                                          2023-02-01 21:12:53.078	warn	script.js.Scripte.test9: DB id: 242 (type: 0) -> number: 0, string: 0, bool: 0 | ioBroker id: 'zigbee.0.00124b00246e6a5d.co2'
                                          
                                          javascript.0
                                          2023-02-01 21:12:53.054	warn	script.js.Scripte.test9: DB id: 241 (type: 0) -> number: 0, string: 0, bool: 0 | ioBroker id: 'javascript.0.System.Sonstige.Tablet_Surface_Akku'
                                          
                                          javascript.0
                                          2023-02-01 21:12:53.031	warn	script.js.Scripte.test9: DB id: 228 (type: 0) -> number: 0, string: 0, bool: 0 | ioBroker id: 'alias.0.HM.Sonstige.Duty_cycle.Wert'
                                          
                                          javascript.0
                                          2023-02-01 21:12:53.008	warn	script.js.Scripte.test9: DB id: 227 (type: 0) -> number: 0, string: 0, bool: 0 | ioBroker id: 'modbus.0.inputRegisters.1.30053_Total_system_power'
                                          
                                          javascript.0
                                          2023-02-01 21:12:52.970	warn	script.js.Scripte.test9: DB id: 226 (type: 0) -> number: 0, string: 0, bool: 0 | ioBroker id: 'modbus.0.inputRegisters.1.30017_Phase_3_active_power'
                                          
                                          javascript.0
                                          2023-02-01 21:12:52.898	warn	script.js.Scripte.test9: DB id: 225 (type: 0) -> number: 0, string: 0, bool: 0 | ioBroker id: 'modbus.0.inputRegisters.1.30015_Phase_2_active_power'
                                          
                                          javascript.0
                                          2023-02-01 21:12:52.868	warn	script.js.Scripte.test9: DB id: 224 (type: 0) -> number: 0, string: 0, bool: 0 | ioBroker id: 'modbus.0.inputRegisters.1.30013_Phase_1_active_power'
                                          
                                          javascript.0
                                          2023-02-01 21:12:52.840	warn	script.js.Scripte.test9: DB id: 223 (type: 0) -> number: 0, string: 0, bool: 0 | ioBroker id: 'libre.0.168e5f9c-3b6c-11ed-b7a7-0242ac110008.graph.connection.glucoseMeasurement.Value'
                                          
                                          javascript.0
                                          2023-02-01 21:12:52.813	warn	script.js.Scripte.test9: DB id: 133 (type: 0) -> number: 0, string: 0, bool: 0 | ioBroker id: 'hm-rega.0.PEQ1453161.0.DUTY_CYCLE'
                                          
                                          javascript.0
                                          2023-02-01 21:12:52.788	warn	script.js.Scripte.test9: DB id: 128 (type: 2) -> number: 0, string: 0, bool: 0 | ioBroker id: 'hm-rpc.0.LEQ0425576.1.STATE'
                                          
                                          javascript.0
                                          2023-02-01 21:12:52.758	warn	script.js.Scripte.test9: DB id: 126 (type: 2) -> number: 0, string: 0, bool: 0 | ioBroker id: 'hm-rpc.0.MEQ0273625.1.STATE'
                                          
                                          javascript.0
                                          2023-02-01 21:12:52.731	warn	script.js.Scripte.test9: DB id: 124 (type: 2) -> number: 0, string: 0, bool: 0 | ioBroker id: 'hm-rpc.0.OEQ0928918.1.STATE'
                                          
                                          javascript.0
                                          2023-02-01 21:12:52.707	warn	script.js.Scripte.test9: DB id: 119 (type: 2) -> number: 0, string: 0, bool: 0 | ioBroker id: 'hm-rpc.0.LEQ0031112.1.MOTION'
                                          
                                          javascript.0
                                          2023-02-01 21:12:52.676	warn	script.js.Scripte.test9: DB id: 90 (type: 0) -> number: 0, string: 0, bool: 0 | ioBroker id: 'javascript.0.System.Sonstige.Tablet_Wz_Akku'
                                          
                                          BananaJoe 1 Reply Last reply Reply Quote 0
                                          • BananaJoe
                                            BananaJoe Most Active @bahnuhr last edited by

                                            @bahnuhr ahh, da liegt der Hase im Pfeffer - deine Datenbank heißt nicht "iobroker".
                                            Zufällig hieß die bei mir auch so.
                                            iobroker.datapoints ist die Tabelle datapoints aus der Datenbank iobroker

                                            Also 2 Dinge sollte man noch als Parameter an den Anfang setzen, die Instanz und den Namen der Datenbank - wobei der auch vermutlich weggelassen werden könnte da diese ja schon im SQL-Adapter festgelegt ist.

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate
                                            FAQ Cloud / IOT
                                            HowTo: Node.js-Update
                                            HowTo: Backup/Restore
                                            Downloads
                                            BLOG

                                            895
                                            Online

                                            31.7k
                                            Users

                                            79.9k
                                            Topics

                                            1.3m
                                            Posts

                                            16
                                            87
                                            9510
                                            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