Jump to content

Arithmetischer Überlauffehler beim Konvertieren


Der letzte Beitrag zu diesem Thema ist mehr als 180 Tage alt. Bitte erstelle einen neuen Beitrag zu Deiner Anfrage!

Empfohlene Beiträge

Hallo,

bin neu im Forum und habe da mal ein Problem,

 

Habe eine Prozedur, die diverse Werte mit 'sp_executesql' berechnet.

 

Wenn ich den benötigten Datumswert als String übergebe läuft das Script ohne Probleme, aber sobald ich die Werte aus einer anderen Tabelle abhole und konvertiere, bekomme ich bei der Ausführung folgende Fehlermeldung:

 

Meldung 8115, Ebene 16, Status 2, Zeile 1

Arithmetischer Überlauffehler beim Konvertieren von expression in den datetime-Datentyp.

 

Hier mal der entsprechende Code dazu:

 

Declare @vonDate datetime;

Declare @BisDate datetime;

 

 

select top (1) @VonDate = Von, @BisDate = Bis from tb_Zeitraum order by id desc

 

set @attrlist = 'path, depth, ds, o, knotenid, von, bis, duration_min, s_total_min, s_fail_min, s_avail';

set @tablename = 'tb_L9_Ergebnis_ApplMain';

 

set @gt = 'GetTree (' + convert(varchar, @knotenid) + ', ' + convert(varchar, @startknotenid) + ', 1, '

set @gt = @gt + convert(varchar, @vonDate, 112) + ', ' + convert(varchar,@bisDate, 112) + ', ' + '''''' + ')';

--set @gt = @gt + '''20100801''' + ', ' + '''20100901''' + ', ' + '''''' + ')';

set @s2 = N'insert into ' + @tablename + ' (' + @attrlist + ') select ' + @attrlist + ' from ' + @gt + ' order by path, depth, knotenid, o'

 

exec sp_executesql @s2

 

Wenn ich nun anstatt set @gt + @gt + convert....

die auskommentierte Zeile verwende funktioniert das ohne Probleme.

 

Würde mich über Hilfe sehr freuen.

 

Jörg

Link zu diesem Kommentar

Sorry,

 

Ich habe mir keinen zusammengebauten String, der mit sp_executesql aufgerufen wir,sondern ein SQL-Statement erstellt, damit hat dann das konvertieren wunderbar funktioniert.

 

Declare @vonDate datetime;

Declare @BisDate datetime;

 

 

select top (1) @VonDate = Von, @BisDate = Bis from tb_Zeitraum order by id desc

 

Insert Into Tabelle (path, depth, ds, o, knotenid, von, bis, duration_min, s_total_min, s_fail_min, s_avail)

Select path, depth, ds, o, knotenid, von, bis, duration_min, s_total_min, s_fail_min, s_avail

From GetTree (knotenid, startknotenid, 1, convert(varchar, @vonDate, 112), convert(varchar, @bisDate, 112), '';

 

So funktioniert es.

Link zu diesem Kommentar
Der letzte Beitrag zu diesem Thema ist mehr als 180 Tage alt. Bitte erstelle einen neuen Beitrag zu Deiner Anfrage!

Schreibe einen Kommentar

Du kannst jetzt antworten und Dich später registrieren. Falls Du bereits ein Mitglied bist, logge Dich jetzt ein.

Gast
Auf dieses Thema antworten...

×   Du hast formatierten Text eingefügt.   Formatierung jetzt entfernen

  Only 75 emoji are allowed.

×   Dein Link wurde automatisch eingebettet.   Einbetten rückgängig machen und als Link darstellen

×   Dein vorheriger Inhalt wurde wiederhergestellt.   Editor-Fenster leeren

×   Du kannst Bilder nicht direkt einfügen. Lade Bilder hoch oder lade sie von einer URL.

×
×
  • Neu erstellen...