Neu Korrektes Datumsformat in SQL-Abfrage

Ahok

Aktives Mitglied
11. September 2023
185
8
Unten befinden sich Teile eines SQL-Mitschnitts einer Statistik-Auswertung. Daraus soll eine Workflow Mail werden, die einmal im Monat versendet wird. Im Mitschnitt ist schon jeweils ein spezielles Datum eingesetzt in den DECLARE Anweisungen. Wie kriege ich das Variabel hin, damit immer das Datum von heute und das Datum von heute+1 Monat genommen wird?

Ich habe schon damit rumgespielt und versucht und BETWEEN GETDATE() AND DATEADD(month, 1, GETDATE()) unten einzufügen (fünfte Zeile von unten), aber das scheint ein falsches Datumsformat unten einzufügen und die Abfrage kommt leer zurück. Die DECLARE Anweisung verstehe ich nicht ganz. Ist datetime eine Anweisung oder eine selbsterstellt Variable? Was bedeutet die 120?

Code:
DECLARE @von datetime = CONVERT(datetime, '2024-04-01 00:00:00', 120);
DECLARE @bis datetime = CONVERT(datetime, '2024-04-30 23:59:59', 120);

    SELECT
    ISNULL(NULLIF(KundenAdresse.cFirma, ''), 'Keine Firma') AS Filiale,
    SUM([Verkauf].[tAuftragPosition].fAnzahl) AS Verkaufsmenge,
    ISNULL( MONTH([Verkauf].[tAuftrag].dErstellt), 0) AS Monat

FROM
    [Verkauf].[tAuftragPosition]

LEFT JOIN [tArtikel] ON [tArtikel].kArtikel = [Verkauf].[tAuftragPosition].kArtikel
JOIN [Verkauf].[tAuftrag] ON [Verkauf].[tAuftrag].kAuftrag = [Verkauf].[tAuftragPosition].kAuftrag
JOIN [tkunde] ON [tkunde].kKunde = [Verkauf].[tAuftrag].kKunde
JOIN [tAdresse] AS KundenAdresse ON KundenAdresse.kKunde = [tkunde].kKunde AND (KundenAdresse.nStandard IN (1)) AND (KundenAdresse.nTyp IN (1))
    WHERE
([Verkauf].[tAuftrag].nType IN (1)) AND
    ([Verkauf].[tAuftrag].nStorno IN (0)) AND
    (ISNULL([tkunde].kKunde, 0) IN (65255,65418,65420,65421,66071,66653,83532)) AND
    (ISNULL([tArtikel].kHersteller, 0) IN (804)) AND
    ([Verkauf].[tAuftrag].dErstellt IS NOT NULL AND [Verkauf].[tAuftrag].dErstellt BETWEEN @von AND @bis)
GROUP BY
    ISNULL(NULLIF(KundenAdresse.cFirma, ''), 'Keine Firma'),
    ISNULL( MONTH([Verkauf].[tAuftrag].dErstellt), 0)
ORDER BY Verkaufsmenge DESC;
;
 
Zuletzt bearbeitet:

Christoph E.

Gut bekanntes Mitglied
Mitarbeiter
11. Oktober 2021
80
60
Die 120 im Zusammenhang mit CONVERT sorgt für eine spezielle Formatierung eines Datums als String im Format "yyyy-mm-dd hh:mi:ss", siehe [CAST und CONVERT (Transact-SQL)] (was hier aber eigentlich unnötig ist, da die Variable sowieso vom Typ DATETIME und nicht STRING ist).

Die DECLAREs erzeugen zwei Variablen @von und @bis, die dann unten im SQL verwendet werden.
Für Deinen Fall solltest Du am Besten den SQL unten unverändert lassen und stattdessen oben die gewünschten Datums im DECLARE auf die gewünschten Werte anpassen:

DECLARE @von datetime = DATEADD(MONTH, -1, GETDATE());
DECLARE @bis datetime = GETDATE();
(ich interpretiere das mal so, das Du die Daten aus dem letzten Monat anzeigen willst)
 
Zuletzt bearbeitet:
  • Gefällt mir
Reaktionen: Ahok

Ahok

Aktives Mitglied
11. September 2023
185
8
Die 120 im Zusammenhang mit CONVERT sorgt für eine spezielle Formatierung eines Datums als String im Format "yyyy-mm-dd hh:mi:ss", siehe [CAST und CONVERT (Transact-SQL)] (was hier aber eigentlich unnötig ist, da die Variable sowieso vom Typ DATETIME und nicht STRING ist).

Die DECLAREs erzeugen zwei Variablen @von und @bis, die dann unten im SQL verwendet werden.
Für Deinen Fall solltest Du am Besten den SQL unten unverändert lassen und stattdessen oben die gewünschten Datums im DECLARE auf die gewünschten Werte anpassen:


(ich interpretiere das mal so, das Du die Daten aus dem letzten Monat anzeigen willst)
Herzlichsten Dank! Das funktioniert. Und ja zu deiner Interpretation, da wollte ich wohl in die Zukunft gucken 😄
 
Ähnliche Themen
Titel Forum Antworten Datum
Neu JTL Ameise-Import – Problem mit Datumsformat JTL-Ameise - Fehler und Bugs 2
Über SQL Abfragen, Preise eines SCX Angebotes ändern kaufland.de - Anbindung (SCX) 6
Neu Auftragsview per Ameise oder SQL in CSV exportieren User helfen Usern - Fragen zu JTL-Wawi 4
SQL-Abfrage – Stückliste-Artikel ausblenden, nur einzelne Positionen anzeigen JTL-Wawi 1.9 3
SQL-Abfrage für eigene Übersicht im Verkauf – Aufträge zu Angeboten prüfen JTL-Wawi 1.9 2
Neu Suche SQL Abfrage für Hersteller die keinem Artikel mehr zugeordnet sind. User helfen Usern - Fragen zu JTL-Wawi 6
MS SQL von JTL an N8N anbinden JTL-Wawi 1.9 16
Neu SQL Abfrage für offene Aufträge über Ameise User helfen Usern - Fragen zu JTL-Wawi 5
Neu Suche Kenner der MS SQL Datenbanken und JTL-WaWi vorzugsweise Raum Aachen Dienstleistung, Jobs und Ähnliches 1
Mehrere SQL Server JTL-Wawi 1.9 6
Neu Shop Komplettabgleich nicht möglich, Globale Daten verstopft SQL Tabelle tGlobalsQueue komplett JTL-Wawi - Fehler und Bugs 0
Neu Was passiert wenn ich Amazon Aufträge, Lieferscheine und Rechnungen per SQL aus der WAWI-Datenbank lösche? User helfen Usern - Fragen zu JTL-Wawi 0
Neu Installation MS SQL 2022 Express: Fehler beim Warten auf das Wiederherstellungshandle des Datenbankmoduls Installation von JTL-Wawi 9
SQL Abfrage bei Workflow Datei Schreibn JTL-Wawi 1.9 1
Neu SQL-Abfrage von im Onlineshop aktiven Artikeln JTL Ameise - Eigene Exporte 2
Neu Biete: Windows Server optimiert für JTL und MS SQL Standard Lizenz (8 Monate alt, 42% unter Neupreis) Dienstleistung, Jobs und Ähnliches 1
Gespeicherte Filter (Lagerbewertung) nach SQL Umzug nicht mehr abrufbar JTL-Wawi 1.9 0
Neu Umzug von SQL 2016 Express auf SQL 2019 Standard mit Wawi 1.8.12.2 Installation von JTL-Wawi 10

Ähnliche Themen