AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Spaltenname als Parameter in Stored Procedure
Thema durchsuchen
Ansicht
Themen-Optionen

Spaltenname als Parameter in Stored Procedure

Ein Thema von Jelly · begonnen am 29. Aug 2005 · letzter Beitrag vom 30. Aug 2005
 
Benutzerbild von Jelly
Jelly

Registriert seit: 11. Apr 2003
Ort: Moestroff (Luxemburg)
3.741 Beiträge
 
Delphi 2007 Professional
 
#13

Re: Spaltenname als Parameter in Stored Procedure

  Alt 30. Aug 2005, 11:55
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.
  Mit Zitat antworten Zitat
 


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 15:59 Uhr.
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-2025 by Thomas Breitkreuz