Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2005.08.21;
Скачать: CL | DM;

Вниз

Обращение к User Defined Function в MS SQL Server   Найти похожие ветки 

 
Алёна   (2005-07-08 14:15) [0]

Есть User Defined Function (вот ее текст):
CREATE FUNCTION dbo.F_GET_COST_STDX (@inIDI int, @inIDX int, @inIDU int, @inDATE datetime, @inIDCJ int)
RETURNS decimal(18,2)
AS
BEGIN
declare @VL_FKV decimal(18,2), @VL_FKC decimal(18,2), @VL_IDCR_PH int, @VL_COST decimal(18,2)
select top 1 @VL_COST = TP_PD.FCOST, @VL_IDCR_PH = TP_PH.IDCURR
from TP_PD
join TP_PH on TP_PH.ID=TP_PD.IDH
where TP_PD.ID = dbo.F_GET_COST_ID(@inIDI, @inIDX, @inIDU, @inDATE, @inIDCJ)
select top 1 @VL_FKV = TM_HY.FKV, @VL_FKC = TM_HY.FKC
from TM_HY
where TM_HY.FDATE <= @inDATE and IDCR_DST = 1 and IDCR_SRC = @VL_IDCR_PH
order by TM_HY.FDATE desc
return (select round(@VL_COST * @VL_FKV * @VL_FKC, 2))
END
Пытаюсь обратиться к ней, используя ADOQuery:
ADOQuery3.SQL.Text := "declare @d datetime set @d = getdate() SELECT * FROM dbo.F_GET_COST_STDX(" + ClientDataSet1.FieldByName("OurCode").Value + ", NULL, NULL, @d, NULL)";
ADOQuery3.Open;
ClientDataSet1.FieldByName("OurPrice").Value := ADOQuery3.Fields[0].Value;

На ADOQuery.Open падает со словами "Invalid object name "dbo.F_GET_COST_STDX ""...


 
Алёна   (2005-07-08 14:26) [1]

Причем если убрать DECLARE....SET и запрос сделать таким:
SELECT * FROM dbo.F_GET_COST_STDX(" + ClientDataSet1.FieldByName("OurCode").Value + ", NULL, NULL, GetDate(), NULL), то говорит, что "Incorrect symbol near "GetDate""


 
just_me   (2005-07-08 14:28) [2]

Данную функцию надо вызывать так:
declare @result decimal(18,2)
select @result = dbo.F_GET_COST_STDX(...)


 
Danilka ©   (2005-07-08 14:30) [3]

SELECT * FROM dbo.F_GET_COST_STDX ...

выделеное жирным - лишнее.


 
Fay ©   (2005-07-08 14:33) [4]

2 Алёна   (08.07.05 14:15)
Или просто
declare @d datetime
select @d = getdate()
SELECT {[БАЙДА] = }dbo.F_GET_COST_STDX(...)



 
Алёна   (2005-07-08 14:41) [5]

to Danilka:
Спасибо!
to just_me:
такой запрос не пролазит, говорит, does not return any resultset


 
Fay ©   (2005-07-11 08:38) [6]

2 Алёна   (08.07.05 14:41) [5]
Купите себе толстенький букварик по MSSQL, и жизнь Ваша будет проще.



Страницы: 1 вся ветка

Текущий архив: 2005.08.21;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.026 c
4-1119601538
webpauk
2005-06-24 12:25
2005.08.21
Изменение иконки


3-1121247715
Ильин Александр
2005-07-13 13:41
2005.08.21
падает IDAPI32


14-1122355970
ANB
2005-07-26 09:32
2005.08.21
Пересмотр результатов залоговых аукционов


1-1122583919
ronyn
2005-07-29 00:51
2005.08.21
Реестр и Install Shield


5-1093530180
SEROGA
2004-08-26 18:23
2005.08.21
Создание компонентов