Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Off Topic
  4. Grafana
  5. [GELÖST] Table mit mehreren Queries - Versatz entfernen

NEWS

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    17
    1
    2.0k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    927

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.2k

[GELÖST] Table mit mehreren Queries - Versatz entfernen

Scheduled Pinned Locked Moved Grafana
4 Posts 2 Posters 351 Views 2 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • T Offline
    T Offline
    T-147
    wrote on last edited by T-147
    #1

    Guten Morgen, allerseits.

    Ich hab jezt seit gut 2 Jahren ein Balkonkraftwerk, dessen Daten ich mit Grafana (aus InfluxDB) visuell aufbereite.
    Dazu wollte ich mir jetzt eine Tabelle über die verschiedenen Abrechnungsjahre (beginnen immer am 01. April) erstellen lassen.
    Leider hat sich die vorhandene Technik im Luaf der Zeit verändert (Stromzähler getauscht zB) und dadurch muss ich für das erste und für das zweite Jahr separate Queries erstellen, um am Ende die richtigen Werte auszubekommen. D.h. ich habe jetzt also 3 Queries in dieser Tabelle.
    Das Problem besteht jetzt darin, dass die Werte der 3 Queries nicht gemeinsam in den entsprechenden Spalten angezeigt werden, sondern nebeneinander versetzt:

    ef3489c9-0f06-41fc-a813-f96789bd46dc-grafik.png

    Um überhaupt alles gleichzeitig angezeigt zu bekommen, war eine Transformation (Outer Time series) notwendig.

    Hat jemand eine Idee, wie ich die Spalten jetzt auch vernünftig untereinander bekomme?
    Die 3 Queries unterscheiden sich aktuell eigentlich nur durch die zeitliche Range (ohne Überschneidung) und "fill value"-Werte. Die Mappings einzelner Werte sollen/können bei der aktuellen Query eigentlich entfernt werden, aber so weit bin ich noch gar nicht gekommen, wegen dieses optischen Schönheitsfehlers.

    Als Beispiel hier mal eines der 3 Queries:

    from(bucket: "ioBroker")
      |> range(start: 2024-01-04T00:00:00Z, stop: 2025-03-31T23:59:59Z)
      |> filter(fn: (r) => r._measurement == "PV_Inverter___Ertrag_total" or  r._measurement == "Strompreis_kWh" or r._measurement == "SmartMeter___Einspeisung_gesamt")
      |> filter(fn: (r) => r._field == "value")
      |> aggregateWindow(every: 1y, offset: 3mo, fn: last, timeSrc: "_start")
      |> pivot(rowKey: ["_time"], columnKey: ["_measurement"], valueColumn: "_value")
      |> difference(columns: ["PV_Inverter___Ertrag_total", "SmartMeter___Einspeisung_gesamt" ])
      |> fill(column: "SmartMeter___Einspeisung_gesamt", value: 261.77)
      |> map(fn: (r) => ({ r with Eigennutzung: r.PV_Inverter___Ertrag_total - r.SmartMeter___Einspeisung_gesamt }))
      |> map(fn: (r) => ({ r with Effizienz: (r.PV_Inverter___Ertrag_total - r.SmartMeter___Einspeisung_gesamt) / r.PV_Inverter___Ertrag_total }))
      |> map(fn: (r) => ({ r with verschenkt: r.SmartMeter___Einspeisung_gesamt * r.Strompreis_kWh }))
      |> map(fn: (r) => ({ r with Ersparnis: (r.PV_Inverter___Ertrag_total - r.SmartMeter___Einspeisung_gesamt) * r.Strompreis_kWh }))
    
    

    Gruß und guten Start in die neue Woche
    Marian

    Marc BergM 1 Reply Last reply
    0
    • T T-147

      Guten Morgen, allerseits.

      Ich hab jezt seit gut 2 Jahren ein Balkonkraftwerk, dessen Daten ich mit Grafana (aus InfluxDB) visuell aufbereite.
      Dazu wollte ich mir jetzt eine Tabelle über die verschiedenen Abrechnungsjahre (beginnen immer am 01. April) erstellen lassen.
      Leider hat sich die vorhandene Technik im Luaf der Zeit verändert (Stromzähler getauscht zB) und dadurch muss ich für das erste und für das zweite Jahr separate Queries erstellen, um am Ende die richtigen Werte auszubekommen. D.h. ich habe jetzt also 3 Queries in dieser Tabelle.
      Das Problem besteht jetzt darin, dass die Werte der 3 Queries nicht gemeinsam in den entsprechenden Spalten angezeigt werden, sondern nebeneinander versetzt:

      ef3489c9-0f06-41fc-a813-f96789bd46dc-grafik.png

      Um überhaupt alles gleichzeitig angezeigt zu bekommen, war eine Transformation (Outer Time series) notwendig.

      Hat jemand eine Idee, wie ich die Spalten jetzt auch vernünftig untereinander bekomme?
      Die 3 Queries unterscheiden sich aktuell eigentlich nur durch die zeitliche Range (ohne Überschneidung) und "fill value"-Werte. Die Mappings einzelner Werte sollen/können bei der aktuellen Query eigentlich entfernt werden, aber so weit bin ich noch gar nicht gekommen, wegen dieses optischen Schönheitsfehlers.

      Als Beispiel hier mal eines der 3 Queries:

      from(bucket: "ioBroker")
        |> range(start: 2024-01-04T00:00:00Z, stop: 2025-03-31T23:59:59Z)
        |> filter(fn: (r) => r._measurement == "PV_Inverter___Ertrag_total" or  r._measurement == "Strompreis_kWh" or r._measurement == "SmartMeter___Einspeisung_gesamt")
        |> filter(fn: (r) => r._field == "value")
        |> aggregateWindow(every: 1y, offset: 3mo, fn: last, timeSrc: "_start")
        |> pivot(rowKey: ["_time"], columnKey: ["_measurement"], valueColumn: "_value")
        |> difference(columns: ["PV_Inverter___Ertrag_total", "SmartMeter___Einspeisung_gesamt" ])
        |> fill(column: "SmartMeter___Einspeisung_gesamt", value: 261.77)
        |> map(fn: (r) => ({ r with Eigennutzung: r.PV_Inverter___Ertrag_total - r.SmartMeter___Einspeisung_gesamt }))
        |> map(fn: (r) => ({ r with Effizienz: (r.PV_Inverter___Ertrag_total - r.SmartMeter___Einspeisung_gesamt) / r.PV_Inverter___Ertrag_total }))
        |> map(fn: (r) => ({ r with verschenkt: r.SmartMeter___Einspeisung_gesamt * r.Strompreis_kWh }))
        |> map(fn: (r) => ({ r with Ersparnis: (r.PV_Inverter___Ertrag_total - r.SmartMeter___Einspeisung_gesamt) * r.Strompreis_kWh }))
      
      

      Gruß und guten Start in die neue Woche
      Marian

      Marc BergM Offline
      Marc BergM Offline
      Marc Berg
      Most Active
      wrote on last edited by Marc Berg
      #2

      @t-147 sagte in Table mit mehreren Queries - Versatz entfernen:

      Hat jemand eine Idee, wie ich die Spalten jetzt auch vernünftig untereinander bekomme?

      Nicht wirklich schön, aber wenn du sowieso mehrere Einzelqueries brauchst, würde ich einfach eine Spalte "_jahr" pro Query anhängen:

          |> map(fn: (r) => ({ r with _jahr: "2024/25" }))
      

      und die Outer Time series durch eine "Merge series/tables" Transformation ersetzen, sowie die _time Spalte ausblenden.

      NUC10I3+Ubuntu+Docker+ioBroker+influxDB2+Node Red+EMQX+Grafana

      Pi-hole, Traefik, Checkmk, Conbee II+Zigbee2MQTT, ESPSomfy-RTS, LoRaWAN, Arduino, KiCad

      Benutzt das Voting im Beitrag, wenn er euch geholfen hat.

      T 2 Replies Last reply
      1
      • Marc BergM Marc Berg

        @t-147 sagte in Table mit mehreren Queries - Versatz entfernen:

        Hat jemand eine Idee, wie ich die Spalten jetzt auch vernünftig untereinander bekomme?

        Nicht wirklich schön, aber wenn du sowieso mehrere Einzelqueries brauchst, würde ich einfach eine Spalte "_jahr" pro Query anhängen:

            |> map(fn: (r) => ({ r with _jahr: "2024/25" }))
        

        und die Outer Time series durch eine "Merge series/tables" Transformation ersetzen, sowie die _time Spalte ausblenden.

        T Offline
        T Offline
        T-147
        wrote on last edited by
        #3

        @marc-berg
        Danke für den Tip, das werd ich mal ausprobieren.

        1 Reply Last reply
        0
        • Marc BergM Marc Berg

          @t-147 sagte in Table mit mehreren Queries - Versatz entfernen:

          Hat jemand eine Idee, wie ich die Spalten jetzt auch vernünftig untereinander bekomme?

          Nicht wirklich schön, aber wenn du sowieso mehrere Einzelqueries brauchst, würde ich einfach eine Spalte "_jahr" pro Query anhängen:

              |> map(fn: (r) => ({ r with _jahr: "2024/25" }))
          

          und die Outer Time series durch eine "Merge series/tables" Transformation ersetzen, sowie die _time Spalte ausblenden.

          T Offline
          T Offline
          T-147
          wrote on last edited by
          #4

          @marc-berg
          So, Dein Tip mit dem Mapping war gar nicht notwendig.
          Ein einfaches "Merge series/tables" war vollkommen ausreichend und hat mein Problem gelöst. :blush:
          Keine Ahnung, warum mir diese Option vorher gar nciht aufgefallen ist.

          Das Mapping werd ich mir aber mal anderweitig im Kopf behalten, damit kann ich evtl. noch Anzeige verschönern, da ich jetzt nur die Jahreszahl vorne stehen hab, aber mein Abrechnungsjahr ist ja um 3 Monate versetzt und daher ist die Anzeige nicht 100% stimmig. Aber das ist eher ein kosmetisches Problem der kleineren Sorte.

          Besten Dank für die Hilfe! :+1:

          1 Reply Last reply
          0
          Reply
          • Reply as topic
          Log in to reply
          • Oldest to Newest
          • Newest to Oldest
          • Most Votes


          Support us

          ioBroker
          Community Adapters
          Donate

          372

          Online

          32.6k

          Users

          82.2k

          Topics

          1.3m

          Posts
          Community
          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
          ioBroker Community 2014-2025
          logo
          • Login

          • Don't have an account? Register

          • Login or register to search.
          • First post
            Last post
          0
          • Home
          • Recent
          • Tags
          • Unread 0
          • Categories
          • Unreplied
          • Popular
          • GitHub
          • Docu
          • Hilfe