Neu SQL prozeduren mit #temp Tabellen

mvh

Sehr aktives Mitglied
26. Oktober 2011
767
275
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.590
482
- 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: 5
  • SQLQuery2.sql.txt
    11,7 KB · Aufrufe: 2

mh1

Sehr aktives Mitglied
4. Oktober 2020
1.590
482
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
Sql Abfrage VK Preise pro Kundengruppe für Grafana JTL-Wawi 1.8 9
Neu SQL Query zum Bilder löschen Arbeitsabläufe in JTL-Wawi 3
Neu List & Label - Eigene SQL-Abfrage als Grundlage für Tabelle im Berichtscontainer? User helfen Usern - Fragen zu JTL-Wawi 10
Neu SQL Server kein Mandant auswählbar und Dienst lässt sich nicht starten Installation von JTL-Wawi 2
Neu Ameise-Vorlage per SQL abrufen und Daten als Ergebnis erhalten JTL Ameise - Eigene Exporte 1
Neu SQL DB läuft mit Fehler voll und crasht Server JTL-Shop - Fehler und Bugs 1
Neu SQL Vartable für Reservierte Artikel gesucht User helfen Usern - Fragen zu JTL-Wawi 2
Neu Innerhalb einer Variable -SQL Abfrage- das Wort "fett" schreiben Druck-/ E-Mail-/ Exportvorlagen in JTL-Wawi 2
Neu SQL Eigener Export - Eigene Felder im Auftrag User helfen Usern - Fragen zu JTL-Wawi 7
Neu Wie finde ich per SQL heraus welche Aufträge auf Teillieferbar stehen? JTL Ameise - Eigene Exporte 1
Neu Microsoft SQL unter MS365 Installation von JTL-Wawi 2
Neu SQL Abfrage, 3. Mahnstufe User helfen Usern - Fragen zu JTL-Wawi 1
Neu Variable oder SQL zum Feld "Gewinn netto" (im Auftrag) Eigene Übersichten in der JTL-Wawi 9
Neu SQL Code zur Ausgabe des Verkaufspreis je Kundengruppe User helfen Usern 1
Neu MS SQL Server auf Windows vs Linux Starten mit JTL: Projektabwicklung & Migration 9
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 9
Neu Verdandliste Pro Paket das Gewicht mit ausgeben Druck-/ E-Mail-/ Exportvorlagen in JTL-Wawi 1
Neu Paternoster Umlaufregal mit JTL Wawi möglich? JTL-WMS / JTL-Packtisch+ - Ideen, Lob und Kritik 0
Neu Aufträge mit nicht verfügbaren Artikeln automatisch zurückhalten User helfen Usern - Fragen zu JTL-Wawi 2
Neu WooCommerce Connector Problem mit nachträglich abgebrochenen Bestellungen Onlineshop-Anbindung 0
Neu Überverkäufe mit Kindartikeln - wie richtig einstellen ? User helfen Usern - Fragen zu JTL-Wawi 22
Neu Problem mit Variationen-Artikeln JTL-Shop - Fehler und Bugs 2
Neu WMS - Nachträglicher Labeldruck mit Adressänderung Arbeitsabläufe in JTL-WMS / JTL-Packtisch+ 1
Neu Connector Verhalten mit Tracking Nummern und Versandbestätigungen Shopify-Connector 0
Neu OTTO-Marketplace Versand NICHT mit DHL möglich? Smalltalk 4
Neu Frage an die (Hobby-) Controller: B2C Einzelhandel mit 6% Marketingbudget - das ist normal? Business Jungle 7
Neu Probeme WaWi mit POS verbinden - failed to connect - server IP 127.0.0.1 Einrichtung / Updates von JTL-POS 0
Neu Immense Probleme mit dem Aufschalten neuer Produkte Amazon-Anbindung - Fehler und Bugs 0
Neu Aufträge mit falsche Steuerart angelegt User helfen Usern - Fragen zu JTL-Wawi 0
Neu Wawi Auftrag in JTL POS öffnen (problem mit Kartenzahlung) Allgemeine Fragen zu JTL-POS 0
Neu Wie erstelle ich Bundles mit JTL Wawi? User helfen Usern 0
Auftrag Inlandskunde mit USt-Id - wie erfassen JTL-Wawi 1.7 6
Konfigurationsartikel mit 0 € vs. Preise der einzelnen Komponenten mit 0 € Einrichtung JTL-Shop5 1
Neu Zahlungsart Überweisung mit Skonto Allgemeine Fragen zu JTL-Shop 1
Neu Übersicht Verkauf mit Artikelmenge und durchschnittlichem VK netto Eigene Übersichten in der JTL-Wawi 6
Neu Artikel mit negativem Preis (Gutschein) eingeben kompliziert...geht das einfacher? Allgemeine Fragen zu JTL-POS 3
Neu Shop 5.4 - Error 500 mit aktiviertem JTL Debug JTL-Shop - Fehler und Bugs 8
Neu Preisdarstellung mit der niedrigsten Staffelung Allgemeine Fragen zu JTL-Shop 5
Neu Plugin mit transparentem Hintergrund (Auswahlassistent) Plugins für JTL-Shop 1
Neu Umgang mit Chargen bei mehreren Bestellungen Arbeitsabläufe in JTL-WMS / JTL-Packtisch+ 0
Neu Fehler mit Zugriff auf die Datenbank (Exec Direct). Installation von JTL-Wawi 4
Neu In Filiale umbuchen mit Packungsgröße und dort mit JTL-POS einzeln "verkaufen" User helfen Usern - Fragen zu JTL-Wawi 3
Probleme mit Versandbenachrichtigung versenden JTL-Wawi 1.9 0
Neu Probleme mit PayPal-Plugin: Bestellungen "pending" & doppelte Zahlungen nach Direktzahlung Plugins für JTL-Shop 0
Neu Fehler 500 mit NOVAchild 5.3.1 in JTL-Shop 5.33 Templates für JTL-Shop 2
Neu Neueste Version Paypal Checkout: Rechnungskauf mit Ratepay und Paypal-Kreditkarte sind nicht verfügbar. Plugins für JTL-Shop 21

Ähnliche Themen