Gelöst [WAWI-18606] BUG: Vergleiche "größer als" und "kleiner als" fehlerhaft...

Status
Es sind keine weiteren Antworten möglich.

gutberle

Sehr aktives Mitglied
29. März 2011
1.280
369
Ich habe einen Workflow geschrieben, der in zwei Bedingungen prüft, ob ein Wert entweder größer als 0,05 ist, oder aber ob er kleiner als -0,05 ist, siehe Screenshot.

JTLWawi_WorkflowBedingungFehler_Bedingungen.png

Simuliere ich den Workflow jetzt aber mit einem Datensatz, bei dem der Kriteriumswert -5,00 ist, dann meldet mir der Workflow, dass die erste Bedingung eingetroffen ist, weil -5,00 ja größer als 0,05 sei.

JTLWawi_WorkflowBedingungFehler_GrößerAls.png

Naja, das ist so sicher nicht ganz richtig, aber wenn ich einen anderen Testdatensatz nehme, bei dem der Kriteriumswert 0,00 ist, dann schlägt konsequenterweise auch die andere Vergleichsrichtung voll danbeben und erklärt, Workflow Bedingung 2 sei eingetreten, weil 0,00 ja kleiner als -0,05 sei.

JTLWawi_WorkflowBedingungFehler_KleinerAls.png

Ähem, das ist leider auch nicht so "richtig" richtig. Und führe ich den Workflows mit den selben Datensätzen auch aus und simuliere ihn nicht nicht, dann wird der Workflow auch genauso falsch ausgeführt wie simuliert, egal ich ihn aus dem Simulationsmodus heraus oder aus der Wawi ausführe.

Vielleicht könntet Ihr mal schauen, was da los ist ... o_O
 

gutberle

Sehr aktives Mitglied
29. März 2011
1.280
369
Nachtrag: Das Problem betrifft nicht nur "kleiner als" und "größer als", sondern genauso auch "kleiner gleich" und "größer gleich".
Alle anderen Vergleiche scheinen zu funktionieren, inklusive "ungleich", der ganz ähnlich ist, aber der sieht mir wie ein String-Vergleich aus...
 

gutberle

Sehr aktives Mitglied
29. März 2011
1.280
369
Guten Morgen Björn,

hier die Erweiterte Eigenschaft. Es geht darum, das Gesamtkundensaldo bestehend aus offenen Rechnungsbeträgen plus zugehörigen Gebühren und Zinsen aus der DB zu holen...
Code:
{% capture query %}\
    SELECT SUM(ROUND(fWert,2)-ROUND(fZahlung,2)-ROUND(fGutschrift,2)+Round(vBestellungEckdaten.fGutschein,2)) FROM vBestellungEckdaten \
        JOIN tBestellung ON vBestellungEckdaten.kBestellung=tBestellung.kBestellung \
        WHERE tBestellung.cType='B' AND tBestellung.tRechnung_kRechnung>0 AND tBestellung.tKunde_kKunde={{ Vorgang.InterneKundennummer }}\
{% endcapture -%}
{% assign OffenerWert = query | DirectQueryScalar | Plus: 0 %}

{% capture query %}\
    SELECT SUM(ROUND(ISNULL(tZahlungsErinnerung.fGebuehr, 0.0),2)) FROM tBestellung
    LEFT JOIN trechnung ON trechnung.tBestellung_kBestellung=tBestellung.kBestellung
    LEFT JOIN tZahlungsErinnerung ON tZahlungsErinnerung.kRechnung=trechnung.kRechnung
        AND NOT EXISTS
            (SELECT * FROM dbo.tZahlungsErinnerung tmp WHERE tmp.kRechnung = tRechnung.kRechnung
                AND tmp.nMahnstufeAktuell > dbo.tZahlungsErinnerung.nMahnstufeAktuell)
    WHERE tBestellung.cType='B' AND tBestellung.tRechnung_kRechnung>0 AND tBestellung.tKunde_kKunde={{ Vorgang.InterneKundennummer }}\
{% endcapture -%}
{% assign OffenerZins = query | DirectQueryScalar | Plus: 0 %}

{% assign OffenerBetrag = OffenerWert | Plus: OffenerZins %}
{{ OffenerBetrag | FormatNumber: 'N2', 'de-DE' }}

... der Fehler zeigt sich aber auch, wenn Du einfach Zahlenwerte im Fenster der Erweiterten Eigenschaft anlegst und zurückgibst.

Gruß,
Ingmar
 

Björn Ponsen

Moderator
Mitarbeiter
1. Juli 2016
893
74
Guten Morgen Ingmar,

du kannst in DotLiquid mit allen Werten arbeiten, der Ausgabe Wert ist jedoch immer ein String.
 

gutberle

Sehr aktives Mitglied
29. März 2011
1.280
369
Hallo Björn,

falls Du damit sagen willst, dass man Werte, die man sich über "Erweiterte Eigenschaften" ziehen muß, weil sie in der Wawi fehlen, schlicht nicht bezüglich ihres numerischen Inhalts interpretieren kann, dann gehe ich mal vorsichtshalber davon aus, dass auch Du das für eine höchst unzufriedenstellende Antwort hältst, oder?

Hast Du vielleicht einen Vorschlag für mich, wie man in einer solchen Situation zum Ziel kommen kann? Die Wawi DB speichert ja nicht nur Strings sondern vor allem Zahlenwerte und "Business" definiert sich auch nicht über die Betrachtung und den Vergleich von Texten, sondern über den Vergleich von Zahlen. Es ist also wohl nicht allzu weit hergeholt, dass ich einen Wert (sic!) aus der Datenbank holen will und dann schauen möchte, ob er größer oder kleiner als ein Zielkritierium ist, oder? ... :confused:

Gruß,
Ingmar
 

Xantiva

Sehr aktives Mitglied
28. August 2016
1.653
273
Düsseldorf
Temporärer Kompromiss: Erledige den Vergleich in der Erweiterten Eigenschaft:
kleiner -0,05 machst Du zu 1
größer 0,05 machst Du zu 3
den Rest zu 2

Dann sollte ein Textvergleich erst mal wieder funktionieren. Allerdings ist das in der Tat eine eher unbefriedigende Lösung.
 

Björn Ponsen

Moderator
Mitarbeiter
1. Juli 2016
893
74
Guten Morgen Ingmar,

da hast du recht aber aktuell keine ich dir keine andere Antwort dazu geben. Ich werde die Problematik aber Intern einmal ansprechen das wir hier eine adäquate Lösung finden. ;)
 

gutberle

Sehr aktives Mitglied
29. März 2011
1.280
369
Hallo Björn,

danke für Deine Rückmeldung und danke auch, dass Du das Problem intern ansprechen willst. Ich (und mit mir andere...) weiß das zu schätzen!

In diesem speziellen Fall kann man sich tatsächlich mit einem Konstrukt wie dem von @Xantiva vorgeschlagenen behelfen, aber was wäre zum Beispiel wenn ich ein Datum aus der Datenbank holen muss. Mit Datumsangaben ist schon mit den bisher implementierten Funktionen/Bedingungen in Dotliquid schwer zu arbeiten, mit einem String-Datum, ähem, da fehlt mir im Moment die Phantasie. Das wären prototypisch die Fälle, wo man mit String-Rückgaben wirklich an die Wand läuft.

Gruß,
Ingmar
 

gutberle

Sehr aktives Mitglied
29. März 2011
1.280
369
@Xantiva - Danke für den super Hinweis. Klar, so kann man das hier lösen. Ich habe es jetzt ein bißchen näher an der eigentlichen Intention benannt, aber es ist das Gleiche.

Falls irgendjemand anderes auch Kundenkonto Ausdrucke machen möchte, hier ist der ganze Workflow Code und hier ist der Thread, in dem wir eine Vorlage erarbeitet haben, die einen Kundenkonto-Ausdruck realisiert. Der Weg hier wäre dann alle auszuwertenden Kunden im Bereich "Kunden" zu markieren und den manuellen Workflow "Kontoauszug drucken..." auszulösen. Das geht bei mir ziemlich schnell, ich habe aber auch nur ~350 Kunden, also Vorsicht beim Probieren mit 23.000 Kunden!!!
Code:
{% capture query -%}\
    SELECT SUM(ROUND(fWert,2)-ROUND(fZahlung,2)-ROUND(fGutschrift,2)+Round(tBestellungEckdaten.fGutschein,2)) FROM tBestellungEckdaten \
        JOIN tBestellung ON tBestellungEckdaten.kBestellung=tBestellung.kBestellung \
        WHERE tBestellung.cType='B' AND tBestellung.tRechnung_kRechnung>0 AND tBestellung.tKunde_kKunde={{ Vorgang.InterneKundennummer }}\
{% endcapture -%}
{% assign OffenerWert = query | DirectQueryScalar | Plus: 0 -%}
{% capture query -%}\
    SELECT SUM(ROUND(ISNULL(tZahlungsErinnerung.fGebuehr, 0.0),2)) FROM tBestellung
    LEFT JOIN trechnung ON trechnung.tBestellung_kBestellung=tBestellung.kBestellung
    LEFT JOIN tZahlungsErinnerung ON tZahlungsErinnerung.kRechnung=trechnung.kRechnung
        AND NOT EXISTS
            (SELECT * FROM dbo.tZahlungsErinnerung tmp WHERE tmp.kRechnung = tRechnung.kRechnung
                AND tmp.nMahnstufeAktuell > dbo.tZahlungsErinnerung.nMahnstufeAktuell)
    WHERE tBestellung.cType='B' AND tBestellung.tRechnung_kRechnung>0 AND tBestellung.tKunde_kKunde={{ Vorgang.InterneKundennummer }}\
{% endcapture -%}
{% assign OffenerZins = query | DirectQueryScalar | Plus: 0 -%}
{% assign Kontostand = OffenerWert | Plus: OffenerZins -%}
{% if Kontostand > 0.05 -%}
    {{ 'Soll' | Trim }}
{% elseif Kontostand < -0.05 -%}
    {{ 'Haben' | Trim }}
{% else -%}
    {{ 'Null' | Trim }}
{% endif -%}

Hier wird also "Soll" für Soll, "Haben" für Haben und "Null" für Null zurückgegeben und die Vergleiche im Workflow selbst sind dann einfache String Vergleiche ...

JTLWawi_KundenkontoWorkflow_BedingungStringVergleiche.png

Gruß,
Ingmar
 
  • Gefällt mir
Reaktionen: Guybrush und hula1499
Status
Es sind keine weiteren Antworten möglich.
Ähnliche Themen
Titel Forum Antworten Datum
Neu JTL-Wawi 1.6.32.1 LS-Pos-Auftrag stornieren JTL-Wawi - Fehler und Bugs 0
Neu wawi 1.6 kunden permanet skonto einrichten Arbeitsabläufe in JTL-Wawi 1
Neu Beta Tester gesucht: Potentialanalyse-Tool für JTL WaWi Dienstleistung, Jobs und Ähnliches 0
Neu Unzustellbarkeitsnachricht DHL Versenden 3.0. Wawi 1.5.50.0 JTL-ShippingLabels - Ideen, Lob und Kritik 0
Neu WaWi oder POS ignoriert Indiv. VK-Brutto JTL-Wawi - Fehler und Bugs 0
Neu Wawi 1.6.32.0 eBay-Anbindung - Fehler und Bugs 0
Neu Artikel im Shop die in der WAWI nicht existieren? JTL-Wawi - Fehler und Bugs 2
Neu WAWI App keine Verbindung Installation von JTL-Wawi 0
In Bearbeitung wieso Unterschiedliche Preise in WAWI /ArtikelStamm und Auftrag?? JTL-Wawi - Fehler und Bugs 5
Neu JTL-Wawi 1.6 Der neue Worker kommt - der alte geht... Umfragen rund um JTL 9
Neu JTL Wawi 1.6 Shop Anbindung Anzahl Artikel Arbeitsabläufe in JTL-Wawi 3
Neu Rechnungstexte anpassen JTL WaWI 1.5.47.2 User helfen Usern - Fragen zu JTL-Wawi 8
Beantwortet JTL Wawi App JTL-Wawi - Ideen, Lob und Kritik 1
Neu Automatisch stornierter Auftrag in Woocommerce wird in der Wawi nicht storniert und sogar ausgeliefert WooCommerce-Connector 0
In Diskussion Voraussichtlicher Liefertermin wird in WaWi 1.6 nicht mehr angzeigt Druck-/ E-Mail-/ Exportvorlagen in JTL-Wawi 2
Neu [1.6.x] Wo ist der Inhalt der Tabelle "dbo.tBestellungAlt" seit Wawi 1.6.x hin? User helfen Usern - Fragen zu JTL-Wawi 1
In Diskussion Experte gesucht, Schnittstelle zwischen JTL WaWi und "Fremd"-Onlineshop Dienstleistung, Jobs und Ähnliches 3
Neu [JTL Shop 5.1.1 CE] [Wawi 1.5.51.0] [Bug] Versehentliches Pflegen von englischen Inhalten in der WaWi-> Shop-Abgleich defekt (Sync Exception 3) JTL-Shop - Fehler und Bugs 2
Beantwortet Wawi Worker bleibt stehen JTL-Wawi - Fehler und Bugs 4
Neu JTL Wawi 1.6 - Sortierung Artikel Angebote & Aufträge JTL-Wawi - Ideen, Lob und Kritik 0
Neu Wer nutzt Clickfunnels und wie zieht ihr die Daten in die WaWi? User helfen Usern - Fragen zu JTL-Wawi 0
Neu JTL Wawi 1.6 - Volltextsuche JTL-Wawi - Ideen, Lob und Kritik 0
Neu JTL Wawi 1.6 - "HAN" JTL-Wawi - Ideen, Lob und Kritik 0
Neu Installation von JTL Wawi und Microsoft SQL 2019 unter Windows 11 Installation von JTL-Wawi 0
In Diskussion Preise von Shop 5 in Wawi sind anders JTL-Wawi - Fehler und Bugs 3
Neu Datenbank erstellen für SQL Server 2014 und Wawi 1.4.35.2 Installation von JTL-Wawi 0
Neu Trinkgeld in der Wawi verarbeiten Shopify-Connector 1
Neu Artikel erscheinen nicht in WAWI Artikelliste User helfen Usern - Fragen zu JTL-Wawi 10
Neu script für sqlcmd mit WAWi-Workflow User helfen Usern - Fragen zu JTL-Wawi 0
Beantwortet Allgemeine Hinweise zur WAWI 1.6 JTL-Wawi - Ideen, Lob und Kritik 10
Neu Wawi 1.6.32 JTL-Wawi - Fehler und Bugs 0
Neu WAWI 1.6.32.0 versendete Rechnungsmail wird nicht als versendet angezeigt JTL-Wawi - Fehler und Bugs 0
Neu Sollte Wawi 1.6.0 nicht eigentlich Wawi 2.0.0 heißen? JTL-Wawi - Ideen, Lob und Kritik 1
Neu Buchungsexporte über JTL Wawi abrufen JTL-POS - Ideen, Lob und Kritik 1
Neu Kundengruppen werden vom Connector nicht mehr in die Wawi übertragen JTL-Wawi - Fehler und Bugs 0
Neu Alternative zu Packliste in JTL Wawi >1.6 ? User helfen Usern - Fragen zu JTL-Wawi 1
Neu Wawi 1.6 Freipositionen mit Menge 0 werden nicht mehr in der Rechnung ausgegeben JTL-Wawi - Fehler und Bugs 0
Beantwortet WAWI 1.6.32.0 Rechnungsänderungen werden in der Rechnung nicht übernommen JTL-Wawi - Fehler und Bugs 23
Neu Wawi 1.6.32.0 "Rabatte ignorieren" funktioniert nur innerhalb der Wawi JTL-Wawi - Fehler und Bugs 0
Neu Artikel im JTL Shop ohne Verknüpfung in der JTL Wawi ? JTL-Wawi - Fehler und Bugs 5
Neu WAWI 1.6.32.0 Amacon VCS Auftrag lässt sich nicht stornieren JTL-Wawi - Fehler und Bugs 1
Neu Repricer JTL WAWI 1.6 Open beta JTL-Repricer für JTL-Wawi und Web 8
Neu WAWI 1.6.32.0 Menüpunkt Abonnement verschwunden User helfen Usern - Fragen zu JTL-Wawi 0
Neu Wawi Artikel Meterware / Stückgut bei Amazon Bestellung als Set / Rolle ausbuchen User helfen Usern - Fragen zu JTL-Wawi 0
Neu Wawi 1.6.32.0 Nach Bearbeitung eines Auftrags springt der Tab nicht mehr in die Wawi JTL-Wawi - Fehler und Bugs 1
Neu WAWI 1.6.32.0 Farbe in Aufträgen lassen sich bei VCS nicht setzen. JTL-Wawi - Fehler und Bugs 1
Neu WAWI 1.6.32.0 Das Feld "Anmerkung" un Aufträgen kann bei VCS Bestellungen nicht mehr genutzt werden User helfen Usern - Fragen zu JTL-Wawi 2
Neu Update WaWi von 1.5.51.0 auf 1.6.32.0 Installation von JTL-Wawi 11
Neu Fehlende WAWI Sync Daten auslesen..wie? Installation von JTL-Wawi 2
Neu Statistiken Wawi - Gewinn pro Benutzer in Prozent Arbeitsabläufe in JTL-Wawi 1

Ähnliche Themen