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.