0

我在函数中有一个带有动态查询的变量,我需要将返回值赋值给另一个变量

EXEC @resultIf = @strSQLCount
                    IF @resultIf <> 0 BEGIN
                        SET @last_qtdChaves = @qtdChaves
                        SET @comissao_temp = @resultIf
                    END

但是出现此错误:此名称不是函数中的有效标识符

我已经尝试了所有方法,但我无法解决记住此代码片段在函数内部的问题

- 更新 -

ALTER FUNCTION [dbo].[FN_percentualComissao] 
(
  -- Add the parameters for the function here
  @cod_representante int,
  @cod_cliente int,
  @cod_produto varchar(max)
)
RETURNS float
AS
BEGIN
-- Declare the return variable here
DECLARE @temComissionamento bit,
        @comissao float,
        @strSQL varchar(max),
        @strSQLCount varchar(max)

set @temComissionamento = 1

IF (select ISNULL(comissao_rep,0) as comissao from representantes where cod_representante = @cod_representante) <= 0
    BEGIN
        set @temComissionamento = 0
    END

IF @temComissionamento = 1
    BEGIN
        DECLARE @micro_regiao varchar(max), 
                @cod_canal int, 
                @cod_pagamento int, 
                @cod_grupo_cliente int

        SELECT 
            @micro_regiao = micro_regiao,
            @cod_canal = cod_canal,
            @cod_pagamento = cod_pagamento,
            @cod_grupo_cliente = cod_grupo_cliente
        FROM
            clientes
        WHERE
            cod_cliente = @cod_cliente


    DECLARE @col1 bit,
            @col2 bit,
            @col3 bit,
            @col4 bit,
            @col5 bit,
            @col6 bit,
            @col7 bit,
            @qtdChaves int,
            @last_qtdChaves int,
            @comissao_temp float,
            @resultIf float

    DECLARE c CURSOR FOR
        SELECT col1,
               col2,
               col3,
               col4,
               col5,
               col6,
               col7
        FROM comissoes_repres_tbverdade 
        ORDER BY col1 DESC, col2 DESC, col3 DESC, col4 DESC, col5 DESC, col6 DESC, col7 DESC

    OPEN c
    FETCH NEXT FROM c INTO @col1, @col2, @col3, @col4, @col5, @col6, @col7

    SET @last_qtdChaves = 0
    While (@@FETCH_STATUS=0) BEGIN

        SET @strSQL = 'SELECT ISNULL(perc_comissao,0) as comissao FROM comissoes_repres WHERE 1 = 1 '
        SET @qtdChaves = 0

        IF @col1 = 1 
            BEGIN
                set @strSQL += ' AND (regiao = '''+@micro_regiao+''') '
                set @qtdChaves = @qtdChaves + 1
            END
        ELSE
            BEGIN
                set @strSQL += ' AND (regiao = ''?'') '
            END

        IF @col2 = 1 
            BEGIN
                set @strSQL += ' AND (repres = '''+CAST(@cod_representante as varchar)+''') '
                set @qtdChaves = @qtdChaves + 1
            END
        ELSE
            BEGIN
                set @strSQL += ' AND (repres = ''?'') '
            END

        IF @col3 = 1 
            BEGIN
                set @strSQL += ' AND (condicao_pag = '''+CAST(@cod_pagamento as varchar)+''') '
                set @qtdChaves = @qtdChaves + 1
            END
        ELSE
            BEGIN
                set @strSQL += ' AND (condicao_pag = ''?'') '
            END

        IF @col4 = 1 
            BEGIN
                set @strSQL += ' AND (canal_vendas = '''+CAST(@cod_canal AS varchar)+''') '
                set @qtdChaves = @qtdChaves + 1
            END
        ELSE
            BEGIN
                set @strSQL += ' AND (canal_vendas = ''?'') '
            END

        IF @col5 = 1 
            BEGIN
                set @strSQL += ' AND (grupo_cliente = '''+CAST(@cod_grupo_cliente AS varchar)+''') '
                set @qtdChaves = @qtdChaves + 1
            END
        ELSE
            BEGIN
                set @strSQL += ' AND (grupo_cliente = ''?'') '
            END

        IF @col6 = 1 
            BEGIN
                set @strSQL += ' AND (familia_comercial = '''+SUBSTRING(@cod_produto,3,2)+''') '
                set @qtdChaves = @qtdChaves + 1
            END
        ELSE
            BEGIN
                set @strSQL += ' AND (familia_comercial = ''?'') '
            END

        IF @col7 = 1 
            BEGIN
                set @strSQL += ' AND (item = '''+CAST(@cod_produto AS VARCHAR)+''') '
                set @qtdChaves = @qtdChaves + 1
            END
        ELSE
            BEGIN
                set @strSQL += ' AND (item = ''?'') '
            END
        SET @comissao_temp = 0
        SET @strSQLCount = N'SELECT COUNT(*) FROM ('+@strSQL+') as t'
        IF @last_qtdChaves <= @qtdChaves
            BEGIN
                EXEC @resultIf = @strSQLCount
                IF @resultIf <> 0 BEGIN
                    SET @last_qtdChaves = @qtdChaves
                    SET @comissao_temp = @resultIf
                END
            END
        IF @comissao_temp = 0 BEGIN
            SElECT @comissao_temp = ISNULL(comissao_rep,0)
            FROM representantes
            WHERE cod_representante = @cod_representante

            SET @comissao = 0

            IF @comissao_temp <> 0 BEGIN
                SET @comissao = @comissao_temp
            END
        END

        FETCH NEXT FROM c INTO @col1, @col2, @col3, @col4, @col5, @col6, @col7
    END
    CLOSE c
    DEALLOCATE c
END

return @comissao

结尾

4

0 回答 0