Neu SQL prozeduren mit #temp Tabellen

mvh

Sehr aktives Mitglied
26. Oktober 2011
1.015
371
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
137
15
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.835
551
- 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
137
15
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
137
15
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
137
15
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: 6
  • SQLQuery2.sql.txt
    11,7 KB · Aufrufe: 2

mh1

Sehr aktives Mitglied
4. Oktober 2020
1.835
551
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 Wie lässt sich der Lieferstatus von Aufträgen per SQL abfragen? User helfen Usern - Fragen zu JTL-Wawi 4
Neu JTL Wawi auf Windows Server 2025 mit SQL 2025? Installation von JTL-Wawi 4
Neu JTL Diag / SQL Mitschnitt lässt sich nicht mehr starten User helfen Usern - Fragen zu JTL-Wawi 6
Neu JTL_DirectQuery - SQL Abfrage Anzahl der Pakete auf Versandliste (DPD) User helfen Usern - Fragen zu JTL-Wawi 3
Neu Welche SQL Server Version für WaWi 1.0.0.0.0 unter Windows 11 Installation von JTL-Wawi 6
Neu Bilder von Kinderartikeln auf Vaterartikel kopieren via SQL Eigene Übersichten in der JTL-Wawi 2
Neu Täglich SQL Backup vom Shop Allgemeine Fragen zu JTL-Shop 2
Kann ich mit dieser SQL Version die neue WaWi 1.11.1 installieren? JTL-Wawi 1.11 2
Neu Kundengruppe per SQL löschen User helfen Usern - Fragen zu JTL-Wawi 3
Neu Sql Express 2022 - wawi sagt beim Start es ist ein Update bereit - gelöst Installation von JTL-Wawi 3
Neu Extern erstelltes SQL - Angebot falsche Werte User helfen Usern - Fragen zu JTL-Wawi 3
Neu In welcher SQL Tabelle finde ich den Ansprechpartner des Herstellers? User helfen Usern - Fragen zu JTL-Wawi 2
Neu Seriennummern und SQL Abfragen User helfen Usern - Fragen zu JTL-Wawi 1
Update SQL Server Management Studio JTL-Wawi 1.10 1
Neu Einrichtung SQL in neuem Rechner funktioniert nicht Installation von JTL-Wawi 3
Neu SQL Code für GPSR Felder (Kaufland) zeigt Fehler + wird daher nicht übertragen kaufland.de - Anbindung (SCX) 0
Neu SQL für noch nie Verkaufte Artikel auf Marktplätzen. User helfen Usern - Fragen zu JTL-Wawi 3
Neu eBay Angebotsimport : Fehler bei der Kommunikation mit dem eA-Server eBay-Anbindung - Fehler und Bugs 0
S/MIME mit veraltetem Standard? JTL-Wawi 1.11 2
Seit Update auf 1.11.4 Workflow für Kartonauswahl gibt error JTL Das Objekt mit Nullwert muss einen Wert haben. BrowsePk: 152325 WorkflowAktionId: 155 JTL-Wawi 1.11 1
Neu Ich möchte konfigurieren, dass Artikel mit einem Lagerbestand von 0 nicht mehr zu einer Bestellung hinzugefügt werden dürfen Eigene Übersichten in der JTL-Wawi 1
Neu "Eine Zeile mit doppeltem Schlüssel" im Assistent zur Einrichtung Installation von JTL-Wawi 1
Neu Konfigurator-Produkt wird mit 0 € in den Warenkorb gelegt JTL-Shop - Fehler und Bugs 2
Neu Probleme mit dem erstellen eines Profils in der Datenbankverwaltung JTL-Wawi - Fehler und Bugs 1
Neu Neues E-Commerce Business mit JTL Wawi - Jtl Shop - Lexware Office (online) - Fragen Starten mit JTL: Projektabwicklung & Migration 2
Neu Kein Abgleich mit Amazon mehr möglich - IP Sperre? Amazon-Anbindung - Fehler und Bugs 2
Neu Eine Amazon-Abrechnung wurde mit Verspätung generiert und fehlt jetzt in WAWI Amazon-Anbindung - Fehler und Bugs 3
Neu Salepix Techniktemplate mit Downloadfehler Templates für JTL-Shop 2
Bestand anderer Kinderartikel wird in Artikelstammdaten mit angezeigt – wie kann man das deaktivieren? JTL-Wawi 1.11 2
Monatsabschluss Amazon FBA UK / CH mit JTL2Datev WaWi 1.10 bei IDU Nutzung und Zwangs VCS für GB / Schweiz JTL-Wawi 1.10 0
Neu Habt ihr auch Probleme mit dem Google Merchant Center? Allgemeine Fragen zu JTL-Shop 6
Neu Mediendateien nicht mit Shopware synchronisiert Shopware-Connector 0
Neu Lieferantenbestellung mit Stückliste User helfen Usern - Fragen zu JTL-Wawi 3
Neu Zahlungsziel mit unterschiedlichen Valutas erstellen User helfen Usern - Fragen zu JTL-Wawi 6
In Diskussion Pos mit 1.11.4 nicht kompatibel Einrichtung / Updates von JTL-POS 9
Neu JTL-MeetUp mit eBay in Berlin Messen, Stammtische und interessante Events 0
Neu Barcodescanner - Artikel mit # wird nicht übergeben Allgemeine Fragen zu JTL-POS 2
Neu Staffelpreise wird mit Sternchen angezeigt - wie ändere ich das Allgemeine Fragen zu JTL-Shop 0
Neu 0,1% an der Kasse erstellte Kunden nicht synchronisiert mit JTL Wawi Allgemeine Fragen zu JTL-POS 0
Neu Probleme mit WMS-Inventur JTL-WMS / JTL-Packtisch+ - Fehler und Bugs 0
Neu GPSR Produktsicherheitsblatt mit Amazon Lister übergeben? Amazon-Lister - Fehler und Bugs 5
Neu Varianten Artikel erstellen mit Lister 2.0 nur für Amazon Amazon-Lister - Ideen, Lob und Kritik 0
Lagerbestände mit der Ameise korrigieren JTL-Wawi 1.6 3
Probleme mit dem Ebay-Abgleich JTL-Wawi 1.11 1
Aktuelle Erfahrungen mit 1.11 JTL-Wawi 1.11 2
Neu Zufällige Preisanpassungen beim Abgleich mit Woocommerce User helfen Usern - Fragen zu JTL-Wawi 9
Amazon-ASIN mit mehreren SKU für Chargenverfolgung JTL-Wawi 1.10 0
Neu Kundenkonto mit mehreren Shop-eMail-Adressen User helfen Usern - Fragen zu JTL-Wawi 0
Neu Ist es korrekt, dass Belegdaten von Amazon (VCS) mit einer etwa 7-tägigen Verzögerung in WAWI landen? Amazon-Anbindung - Fehler und Bugs 8
Neu Ärger mit CountX: Verzögerung bei der Bearbeitung von VCS-Daten in WAWI führt zu unvollständigen Steuerdaten User helfen Usern - Fragen zu JTL-Wawi 0

Ähnliche Themen