Получение синтаксических ошибок при создании функции - PullRequest
0 голосов
/ 13 ноября 2018

Я потратил более 2 часов, пытаясь найти способ найти ответ.

Я совершенно новичок в SQL и MySQL, и я попытался написать следующую функцию:

CREATE FUNCTION fp_spinofffactor (id char(8), startdate date)
RETURNS float
BEGIN
DECLARE spinoffFactor float;               (ERROR- EXPECTED A ";")
select spinoffFactor = ISNULL(EXP(SUM(LOG(spinoffFactor))),1)
from( 
select case when (prev_price- divs) <= 0 THEN 1 
else (prev_price- divs)/prev_price end as spinoffFactor
    from (select
    divs,
    fp_v2.fp_prevUnadjPrice(id, ex_date) as prev_price
from (
select sum(fbd.p_divs_pd) as divs,fbd.p_divs_exdate as ex_date
from fp_v2.fp_basic_dividends fbd
where fbd.fsym_id = id
and fbd.p_divs_s_pd=1
and fbd.p_divs_exdate > startdate
group by fbd.p_divs_exdate ) a ) b ) c; 
return spinofffactor;              ERROR (Return is not valid at this position)
END                                ERROR (END IS NOT VALID AT THIS position)

Но я получаю несколько синтаксических ошибок.Я написал ошибки там, где их получаю.

Мне трудно найти информацию о правилах синтаксиса MySQL и рабочей среды.

Кто-нибудь может помочь?

1 Ответ

0 голосов
/ 13 ноября 2018

Вы должны предоставить разделитель в MySql Workbench, чтобы указать, где начинается и заканчивается ваш код. Предполагая, что ваш синтаксис правильный, вы можете написать, как показано ниже.

DELIMITER $$
CREATE FUNCTION fp_spinofffactor (id char(8), startdate date)
RETURNS float
BEGIN
DECLARE spinoffFactor float;       
    select spinoffFactor = ISNULL(EXP(SUM(LOG(spinoffFactor))),1)
    from( 
    select case when (prev_price- divs) <= 0 THEN 1 
    else (prev_price- divs)/prev_price end as spinoffFactor
        from (select
        divs,
        fp_v2.fp_prevUnadjPrice(id, ex_date) as prev_price
    from (
    select sum(fbd.p_divs_pd) as divs,fbd.p_divs_exdate as ex_date
    from fp_v2.fp_basic_dividends fbd
    where fbd.fsym_id = id
    and fbd.p_divs_s_pd=1
    and fbd.p_divs_exdate > startdate
    group by fbd.p_divs_exdate ) a ) b ) c; 
return spinofffactor;              
END$$
DELIMITER ;

Вы также можете запустить это из командной строки MySQL, и оно должно работать.

...