Neu SQL prozeduren mit #temp Tabellen

mvh

Sehr aktives Mitglied
26. Oktober 2011
746
265
Moin.
Erstens - in deinem Code brauchst Du keine Temp-Table, MAXIMAL Tabellen-Variable, aber auch hier meine Frage - wozu, da ist nur ein SELECT.
Zweitens - eine SP soll in Custom View NICHT benutzt werden, nur Funktionen sind erlaubt (und auch dort kannst Du eine Tabellen-Variable definieren)
Drittens - ein Forum ist nicht nur zum Schreiben da, sondern auch zum Lesen, Lernen, Verstehen und ggf. Akzeptieren.
 
  • Gefällt mir
Reaktionen: wawi-dl

chx_de

Gut bekanntes Mitglied
12. August 2016
134
13
Uff! Hast du die vorherigen Antworten, die du hier erhalten hast überhaupt gelesen? ;)

Das kannst du deshalb nicht speichern, weil zu dem Zeitpunkt, wenn du auf <Speichern> klickst kein #temp1 existiert.
Es gibt jetzt mehrere Möglichkeiten, wie du das umgehen kannst.
Das was ICH machen würde, habe ich in #13 beschrieben:
in der Wawi würde ich die eigene Übersicht als SELECT 'execute eazybusiness.dbo.spToci_JTL_Test @key' eingeben und nach dem dann erfolgreichen speichern: update dbo.tCustomerQuery set cQueryText='execute eazybusiness.dbo.spToci_JTL_Test @key' where convert(varchar(max), cQueryText ) = 'SELECT ''execute eazybusiness.dbo.spToci_JTL_Test @key'''
Jo habe ich. Und mir ist bewusst, dass es zum Zeitpunkt des Speicherns keine #temp gibt. Mir ist auch klar, dass dies der Fehler ist. Das ist aber für das abspeichern eigentlich total irrelevant :) --- also ob eine #temp existiert oder nicht. Hat ja bis zu Version XXX auch immer funktioniert.

- Umgehen könnte man das mit einer festen Tabelle ==> Nachteil bei mehreren gleichzeitigen Zugriffen auf die Tabelle, da die ja immer geleert werden müsste.
- Andere Alternative wäre @temp Tabellen Variablen ==> Nachteil ist, dass die nicht in weiteren Prozeduren zur Verfügung stehen und Probleme mit aggregierten Abfragen machen
- Meine Lösung ist auch die von dir beschriebene, dass ich dann einfach den Code direkt in die Datenbank schreibe.

Trotzdem Danke für die Antworten und die Mühe.

LG
Christian
 

mh1

Sehr aktives Mitglied
4. Oktober 2020
1.509
452
- Umgehen könnte man das mit einer festen Tabelle ==> Nachteil bei mehreren gleichzeitigen Zugriffen auf die Tabelle, da die ja immer geleert werden müsste.
um Probleme, die beim gleichzeitigen Zugriff entstehen könnten bzw. das Locking kümmert sich doch der SQL-Server 🤔
Wenn der Zugriff also das Auslesen einer Tabelle zu Problemen führt (z.b. eine Art von Race Condition), dann ist dies meist ein guter Hinweis darauf, dass die Abfrage überdacht bzw. umgebaut werden muss (bitte nicht als Abwertung deiner SQL Kenntnisse verstehen, sondern nur als gut gemeinten Hinweis).

- Andere Alternative wäre @temp Tabellen Variablen ==> Nachteil ist, dass die nicht in weiteren Prozeduren zur Verfügung stehen und Probleme mit aggregierten Abfragen machen
Aha! Da du anscheinend Daten speichern willst wo verschiedene Stored Procedures drauf zugreifen können, kommst du ja mit der #temp aus der ersten Stored Procedure eh nicht weiter.
Denn die innerhalb der SP erstellte #Temp wird doch beim Verlassen der SP sowieso entfernt ;)

Ich würde jedoch behaupten, dass, wenn Du ständig eine Relation löschen und neu erstellen musst, wahrscheinlich etwas grundsätzlich falsch angegangen wird. Wieder bitte nicht als Abwertung sehen!
Ich würde "einen Schritt zurück machen" (oder auch mehrere?) und anstatt auf das Eigene-Übersichten-speichern Problem eher auf die Abfrage konzentrieren und diese neu denken.
 

chx_de

Gut bekanntes Mitglied
12. August 2016
134
13
Hi,

da muss ich dir leider wiedersprechen :)
Aha! Da du anscheinend Daten speichern willst wo verschiedene Stored Procedures drauf zugreifen können, kommst du ja mit der #temp aus der ersten Stored Procedure eh nicht weiter.
Denn die innerhalb der SP erstellte #Temp wird doch beim Verlassen der SP sowieso entfernt ;)
Das ist so nicht korrekt. Die #temp Tabelle bleibt während der ganzen Sitzung erhalten und wird nur geschlossen, wenn entweder die Sitzung beendet oder aber die Tabelle mit DROP gelöscht wird. Deswegen kannst du dann auch selbstverständlich mit anderen SP auf die Daten in der #temp Tabelle zugreifen.

Damit es bei Create #temp nicht zu einem Fehler kommt, macht es Sinn immer das vorhanden sein der temporären Tabelle zu prüfen
SQL:
drop table if exists #Temp

Ebenso ist es gut, am Ende des Codes die #temp mittels Drop zu löschen.

um Probleme, die beim gleichzeitigen Zugriff entstehen könnten bzw. das Locking kümmert sich doch der SQL-Server
Das ist mir schon klar. Aber ich möchte ja die Daten aus diversen Select Statements in einer temporären Tabelle speichern und auch nur genau diese Daten später weiter verarbeiten. Genau dafür sind temporäre Tabellen oder Tabellenvariablen ja da. Wenn ich mir anstatt einer #temp Tabelle jetzt eine permanente Tabelle anlege, dann kann es sein, dass mehrere Nutzer in unterschiedliche Sitzungen gleichzeitig Daten in diese Tabelle schreiben. Und genau dann gibt es ein Problem in dem nachfolgenden Code. Weil dieser dann Daten weiterverarbeitet, die eigentlich nicht nur USER1 zuzuordnen sind. Noch schlimmer wird es, wenn dann USER1 in seiner Session die Tabelle am Ende mittels DELETE ' leert. Dann wären die Daten für USER 2 auch weg. Kann man sicherlich durch Keys oder SessionIDs lösen.

Aber warum soll ich mir das antun, wenn es genau dafür in T-SQL das Objekt der temporären Tabelle gibt;)

Ich werde morgen mal den angepassten Code posten. Im Grunde geht es um die Auswertung der Amazon Settlement Daten. Ich habe für uns noch die PPC Kosten mit einbezogen. Wir lesen die Amazon ADS API aus, transformieren die Daten und speichern die auch im SQL Server ab. Dann haben wir noch weitere Tabellen mit erweiterten Artikeldaten und Kalkulation Daten, die wir für eine vernünftige Kalkulation bzw. Nachkalkulation benötigen. Diese Daten stehen ja nur uns zur Verfügung, deswegen muss ich den Code mal auf die Abfragen beschränken, die jeder JTL Nutzer von haus aus hat. Wenn jemand Interesse an der Auswertung inklusive PPC etc hat, genre melden .-)
 

chx_de

Gut bekanntes Mitglied
12. August 2016
134
13
Moin.
Erstens - in deinem Code brauchst Du keine Temp-Table, MAXIMAL Tabellen-Variable, aber auch hier meine Frage - wozu, da ist nur ein SELECT.
Zweitens - eine SP soll in Custom View NICHT benutzt werden, nur Funktionen sind erlaubt (und auch dort kannst Du eine Tabellen-Variable definieren)
Drittens - ein Forum ist nicht nur zum Schreiben da, sondern auch zum Lesen, Lernen, Verstehen und ggf. Akzeptieren.
Hi, ich lese und verstehe das schon - mach dir da mal keine Sorgen :) Der Code, den ich zum testen gepostet hatte besteht tatsächlich nur aus einem Select. Das war ja auch nur zum Verständnis des Problems. Die eigentliche Prozedur ist ein wenig komplexer und in dem Code funktioniert dann auch keine @Tabellenvariable mehr. Wie ich weiter oben schon geschrieben habe, werde ich den morgen mal posten

Zweitens - eine SP soll in Custom View NICHT benutzt werden, nur Funktionen sind erlaubt (und auch dort kannst Du eine Tabellen-Variable definieren)
Wo genau steht das? War mit so nicht bekannt und wird von uns schon seit Einführung der Custom Views so praktiziert.
 

chx_de

Gut bekanntes Mitglied
12. August 2016
134
13
So hier im Anhang die beiden SQL Prozeduren. Den Teil mit der PPC Abfrage habe ich auskommentiert, da er ja normalerweise in in JTL zur Verfügung steht.
Sämtlich Kosten für AFN sind in der Settlement Datei enthalten. Für das MFN Porto+ Karton habe ich bei uns fix 4.5 angesetzt. Für die MFN Retouren 5 Euro. Die exakten Daten liegen auch in einer Tabelle und müssen noch in die Abfrage eingebaut werden.

Nicht berücksichtig werden hier in diesem Beispiel: PPC Kosten, Amazon Lager Kosten, Kosten für Remissionen (die würde man aber über sie SP API bekommen), Erlöse durch Erstattung für verlorene Ware, etc.
 

Anhänge

  • SQLQuery1.sql.txt
    13,8 KB · Aufrufe: 4
  • SQLQuery2.sql.txt
    11,7 KB · Aufrufe: 1

mh1

Sehr aktives Mitglied
4. Oktober 2020
1.509
452
Das steht dir natürlich frei.


Das ist so nicht korrekt. Die #temp Tabelle bleibt während der ganzen Sitzung erhalten und wird nur geschlossen, wenn entweder die Sitzung beendet oder aber die Tabelle mit DROP gelöscht wird. Deswegen kannst du dann auch selbstverständlich mit anderen SP auf die Daten in der #temp Tabelle zugreifen.
Das Verhalten der Temp Tables ist hier dokumentiert:
https://learn.microsoft.com/en-us/s...ct-sql?view=sql-server-ver16#temporary-tables
(siehe auch erster Aufzählungspunkt)

Damit es bei Create #temp nicht zu einem Fehler kommt,
Es ist eher unüblich, einen Temp Table zuerst mit Create zu erstellen und dann mit inserts zu befüllen

macht es Sinn immer das vorhanden sein der temporären Tabelle zu prüfen
SQL:
drop table if exists #Temp
Je nach Anwendungsfall kann evtl. schon nötig sein :thumbsup:
Um verschiedene TempTables aber intern zu unterscheiden hängt der SQL-Server an den Namen einfach ein eindeutiges Suffix an.
 
Ähnliche Themen
Titel Forum Antworten Datum
Neu MS SQL Server auf Windows vs Linux Starten mit JTL: Projektabwicklung & Migration 7
Beantwortet Hilfe bei SQL Abfrage erbeten User helfen Usern - Fragen zu JTL-Wawi 3
Neu SQL Abfrage - Sendungsnummern als Liste nach Datum Schnittstellen Import / Export 2
Neu DB: kPlattform eines Auftrages ändern (SQL) - Zwecks Lagerplatzreservierung User helfen Usern - Fragen zu JTL-Wawi 0
Neu Ameise Export in SQL Abfrage umwandeln User helfen Usern - Fragen zu JTL-Wawi 11
Neu Ware direkt in ein Standardlager einbuchen per SQL StoreProcedure dbo.spWarenlagerEingangSchreiben Schnittstellen Import / Export 8
Neu List & Label Vorlagen: SQL Injection Warnung umgehen um Datenquelle zu ergänzen User helfen Usern - Fragen zu JTL-Wawi 12
Neu WAWI 1.9 mit SQL Server Developer User helfen Usern - Fragen zu JTL-Wawi 3
Neu JTL WAWI SQL Dokumentation offline Arbeitsabläufe in JTL-Wawi 2
Neu Hosting der SQL-DB bei JTL User helfen Usern - Fragen zu JTL-Wawi 6
Neu Bild per SQL Query aus lesen aus von Artikel Bildplattform Druck-/ E-Mail-/ Exportvorlagen in JTL-Wawi 0
Neu Umlagerungen - Wie, wo, oder SQL? Arbeitsabläufe in JTL-Wawi 2
Neu SQL Server Update von 2014 auf 2019 oder Neuinstallation? Installation von JTL-Wawi 4
Neu SQL: img alt Tags setzen User helfen Usern - Fragen zu JTL-Wawi 2
[Bug] JTL-Wawi 1.9 | Auftrag: Statustext in Workflow Variablen leer | gelöst: [SQL] JTL-Wawi 1.9 0
Auftrag: Eigene Felder in DotLiquid Vorlage verwenden [Wawi 1.9.4.5] [SQL] JTL-Wawi 1.9 8
Neu Partner für JTL Shop WAWI und MS SQL Server gesucht Dienstleistung, Jobs und Ähnliches 2
Neu Fehler bei SQL-Abfrage durch Aufgabenplanung Gelöste Themen in diesem Bereich 12
Neu SQL Server 2022 Standart auf M.2 NVMe SSD Installation von JTL-Wawi 41
Neu Fehlermeldung "Es wurde im SQL-Server kein Backuppfad hinterlegt" => kein Schemaupdate möglich JTL-Wawi - Fehler und Bugs 8
Neu Nach Update auf SQL 2022 Express keine verbindung mehr mit Client möglich Installation von JTL-Wawi 2
Neu Tabelle aus eigenem SQL in Druckvorlage möglich? Gelöste Themen in diesem Bereich 3
Neu Merkmal eindeutig per SQL zuordnen Druck-/ E-Mail-/ Exportvorlagen in JTL-Wawi 0
Neu Update SQL 2017 Express auf 2022 Standard Installation von JTL-Wawi 7
In Diskussion SQL Update aus Workflow heraus JTL-Workflows - Fehler und Bugs 8
Neu Plugin: WooCommerce Wallet oder Gutscheine mit JTL nutzen - Fehler in der MwSt User helfen Usern - Fragen zu JTL-Wawi 0
Lagerartikel mit Variation, von denen manche kein Lager brauchen JTL-Wawi 1.9 1
Chargennummer eines Artikels auf der Rechnung mit ausdrucken JTL-Wawi 1.9 0
Neu Amazon Custom Orders mit Bildern von Kunden Amazon-Anbindung - Ideen, Lob und Kritik 0
Neu Sales Info / Aussendienst Informationssystem mit Besuchserfassung und vielen weiteren Funktionen auf der JTL Connect 2024 Dienstleistung, Jobs und Ähnliches 1
Neu Export / Exportformate: Anleitung bzw. Infoseite mit zulässigen Tags ? Betrieb / Pflege von JTL-Shop 0
Zahlungsmodul mit DKB klappt nicht JTL-Wawi 1.9 21
Neu neue Tarife mit Shop verstehe ich da was falsch? Allgemeine Fragen zu JTL-Shop 3
Neu Problem mit Scroll-Link nach Update auf Shop-Version 5.3.3 Technische Fragen zu Plugins und Templates 0
Neu Kern Waage die im Netzwerk hängt (via Moxa NPort 5100) auf RDP Server mit WMS nutzen User helfen Usern - Fragen zu JTL-Wawi 0
Neu Hat jemand Erfahrung mit MrPacket? User helfen Usern 0
Neu Abgleich mit JTL Shop läuft nach zahlreichen erfolgreichen Durchläufen nicht mehr weiter JTL-Shop - Fehler und Bugs 11
Neu Wie andere Länder und Sprachen vom Google Shopping Plugin mit dem Merchant Center verbinden Plugins für JTL-Shop 5
Neu Nutzung von JTL POS im B2B Bereich mit späterer Zahlung Allgemeine Fragen zu JTL-POS 0
Neu Abholung mit DHL: Ist das immer so schlimm? User helfen Usern 5
Neu Problem mit Shopify abgleich Shopify-Connector 2
Stücklisten mit begrenzter Stückzahl JTL-Wawi 1.9 2
Auftrag ohne Versand aber mit Lagerbuchung abschließen JTL-Wawi 1.9 1
Neu Ebay Verkäufe - Auswahlartikel mit händischer Auswahl in der Rechnung - wie bei Wawi 1.9 vorgehen ?! Arbeitsabläufe in JTL-Wawi 0
Neu Einstieg in die JTL-Welt – JTL-Start mit Wawi-Lager oder gleich JTL-WMS? User helfen Usern - Fragen zu JTL-Wawi 23
Neu Artikel-Etiketten zusammen mit Pickliste drucken Arbeitsabläufe in JTL-Wawi 0
Neu Amazon Für das Feld "Preis mit Steuern zur Anzeige eBay-Anbindung - Fehler und Bugs 2
Neu "Artikel erscheint" Datum mit auf RE drucken Arbeitsabläufe in JTL-Wawi 2
Neu Erfahrungen mit Temu / Anbindung JTL User helfen Usern - Fragen zu JTL-Wawi 5
Neu Rechnungsvorlage mit Boxennummer Druck-/ E-Mail-/ Exportvorlagen in JTL-Wawi 0

Ähnliche Themen