Delphi-PRAXiS
Seite 2 von 2     12   

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi Spaltenname als Parameter in Stored Procedure (https://www.delphipraxis.net/52403-spaltenname-als-parameter-stored-procedure.html)

Jelly 30. Aug 2005 12:08

Re: Spaltenname als Parameter in Stored Procedure
 
Zitat:

Zitat von Jelly
Ich bin mir aber irgendnie nicht ganz im Klaren, was das mit dem #3 auf sich hat. Sind das etwa temporäre Tabellen, die global gültig sind. Dann träten aber da Probleme auf, wenn die Prozedur parallel ausgeführt wird, oder?

Das hier bestätigt meinen Verdacht und fällt als Lösung auch weg.

jensw_2000 30. Aug 2005 12:48

Re: Spaltenname als Parameter in Stored Procedure
 
@schima
Hast du auch eine Idee wie man Output Parameter auswerten kann ?

SQL-Code:
DECLARE @Statement NVARCHAR(500)
DECLARE @Parameter NVARCHAR(500)
DECLARE @Values NVARCHAR(500)

DECLARE @EResult varchar(50)

SET @Statement = N'SELECT @EResult=Vorname FROM Mitarbeiter WHERE ID = @EInput'

SET @Parameter = N'@EInput INT, @EResult VarChar(50) OUTPUT '

exec sp_executesql @Statement, @Parameter , @EInput=11, @EResult = ''

SELECT @EResult -- ergibt NULL
Wenn man nur Eingabeparameter übergibt funtkioniert die Abfrage ...

SQL-Code:
DECLARE @Statement NVARCHAR(500)
DECLARE @Parameter NVARCHAR(500)
DECLARE @Values NVARCHAR(500)

SET @Statement = N'SELECT Vorname FROM Mitarbeiter WHERE ID = @EInput'

SET @Parameter = N'@EInput INT '

exec sp_executesql @Statement, @Parameter , @EInput=11

-- Vorname
-- -------
-- Susanne

-- 1 Row Affected
Ich denke wir drehen uns da im Kreis, weil der Ausgabeparameter aus EXEC(UTE) wieder nicht rauskommt ...


:hi:



(bin jetzt erstmal eine Weile weg ...)

Jelly 30. Aug 2005 12:55

Re: Spaltenname als Parameter in Stored Procedure
 
Das mit sp_executesql scheint wohl doch interessant zu sein. Habs jetzt aber mal so gelöst, indem ich mir eine feste Tabelle erzeuge namens Spaltennamen. Meine SP sieht dann so aus:
create procedure spQueryMail(
SQL-Code:
create procedure spQueryMail(
@P_ID int,
@Spalte varchar(60),
@MailAddress varchar(255) output)
as
declare @Code varchar(300)
declare @PA_ID int
declare @GUID varchar(40)


set @PA_ID = (Select pa.ID from partner pa, property p where p.Manager=pa.ID and p.ID=@P_ID)
set @GUID = newid()
set @Code = 'insert Spaltennamen select ''' + @GUID + ''', ct.Code from partner p join commtyp ct on p.' + @Spalte + '=ct.ID where p.ID = ' + cast(@PA_ID as varchar(10)) + ' and ct.IsByEMail=1'
execute(@Code)
set @Code = (select Wert from Spaltennamen where GUID=@GUID)
delete from Spaltennamen where GUID=@GUID
set @MailAddress = isnull((select pc.Number from PartnerComm pc, Partner pa, CommTyp ct
                            where pc.Partner=pa.ID and pc.CommTyp=ct.ID and ct.Code=@Code and pa.ID=@PA_ID),'')
Ich speichere den gewünschten Spaltennamen in einer gesonderten Tabelle. Meinen erzeugten Record finde ich anschliessend leicht wieder über die generierte GUID.

Das klappt soweit, ist aber sicherlich weit entfernt von "Performance Tuning", da ja jedesmal ein Record in die Tabelle geschrieben wird.


Alle Zeitangaben in WEZ +1. Es ist jetzt 10:30 Uhr.
Seite 2 von 2     12   

Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz