如何将此函数oracle转换为sql server

时间:2015-01-28 18:04:34

标签: sql-server oracle function

如何将此功能从Oracle转换为SQL Server?

FUNCTION PorcImpuesto (pCompania IN VARCHAR2)
      RETURN FLOAT
   AS
      vImpuesto   FLOAT;
      vLink       VARCHAR (100);
      vTipoIva    VARCHAR (10);

BEGIN
      SELECT NVL (DBLINK, ''), IMPUESTO
        INTO vLink, vTipoIva
        FROM SAV_PAIS
       WHERE COMPANIA = pCompania;

        EXECUTE IMMEDIATE   'SELECT (NVL(IMPUESTO1,0) / 100) 
                    FROM '
                           || pCompania
                           || '.IMPUESTO'
                           || vLink
                           || '
                   WHERE IMPUESTO = '''
                           || vTipoIva
                           || ''''
             INTO vImpuesto;

          RETURN vImpuesto;
       EXCEPTION
          WHEN NO_DATA_FOUND
          THEN
             RETURN 0;
          WHEN OTHERS
          THEN
             RETURN 0;
       END;

2 个答案:

答案 0 :(得分:1)

很难说 - 我没有你的桌子和任何东西 - 但你需要这样的东西 ......

CREATE FUNCTION APEX.PORCIMPUESTO (@pCompania VARCHAR(4000))
RETURNS DECIMAL(20, 4)  -- or whatever precision you need
AS 
BEGIN
    DECLARE @vImpuesto DECIMAL(20, 4)
    DECLARE @vLink     VARCHAR(100) 
    DECLARE @vTipoIva  VARCHAR(10) 

    SELECT  
        @vLink  =  ISNULL(DBLINK, ''),
        @vTipoIva  =  IMPUESTO
    FROM   
        SAV_PAIS 
    WHERE   
        COMPANIA  = @pCompania

    -- declare a NVARCHAR variable to hold the SQL statement you want to execute
    DECLARE @SqlStmt NVARCHAR(1000)

    -- define the SQL query to execute - and **PLEASE** use parameters wherever possible!
    SET @SqlStmt = N'SELECT (ISNULL(IMPUESTO1, 0) / 100) FROM ' + @pCompania + N'.IMPUESTO' + vLink + N' WHERE IMPUESTO = @TipoIva';

    -- try/catch to handle exceptions
    BEGIN TRY
        -- execute the stored procedure and channel data into temporary table
       INSERT INTO #vImpuesto
           EXEC sp_executesql @stmt = @SqlStmt, @params = N'@TipoIva VARCHAR(10)', @TipoIva = @vTipoIva

       -- select all columns, all rows from that temporary table as returned result set
       SELECT *
       FROM #vImpuesto
    END TRY
    BEGIN CATCH
       -- handle your exception case here
    END
END;

答案 1 :(得分:0)

CREATE FUNCTION APEX.PORCIMPUESTO
(
    @pCompania      VARCHAR(4000) 
)
RETURNS FLOAT 
AS 
    BEGIN
        DECLARE @vImpuesto      FLOAT 
        DECLARE @vLink          VARCHAR(100) 
        DECLARE @vTipoIva       VARCHAR(10) 

        SELECT  @vLink  =  ISNULL(DBLINK, ''),
                @vTipoIva  =  IMPUESTO
        FROM    SAV_PAIS 
        WHERE   COMPANIA  = @pCompania

        EXECUTE 'SELECT (ISNULL(IMPUESTO1,0) / 100) 
                FROM '
                       || @pCompania
                       || '.IMPUESTO'
                       || vLink
                       || '
               WHERE IMPUESTO = '''
                       || vTipoIva
                       || ''''
         INTO vImpuesto;

      RETURN @vImpuesto;
   EXCEPTION
      WHEN NO_DATA_FOUND
      THEN
         RETURN 0;
      WHEN OTHERS
      THEN
         RETURN 0;
   END;