Monday, October 11, 2021

ORACLE SQL | Find Number between two values, odd, even, number is odd or even

select '&START_NUM' + level - 1 "Number"

    from dual

  connect by level <= '&END_NUM' - '&START_NUM' + 1



create table numbers (value number);


declare

    x number;

begin

    for x in '&start_num' .. '&end_num'

    loop

        insert into numbers values (x);

    end loop;

end;

/



DECLARE

    -- declare variable num

    num NUMBER(3) := 1;

    sum1 NUMBER(4) := 0;

BEGIN

    WHILE num <= &5 LOOP

        -- display odd number

        dbms_output.Put_line(num);

        -- the sum of all odd numbers

         sum1 := sum1 + num;

        --next odd number

        num := num + 2;

    -- end  loop

    END LOOP;

dbms_output.Put_line('Sum of all odd numbers is '|| sum1);

END;

/


DECLARE
    -- declare variable num
    num NUMBER(3) := &start_odd;
    sum1 NUMBER(4) := 0;
BEGIN
    WHILE num <= &end_odd LOOP
        -- display odd number
        dbms_output.Put_line(num);
        -- the sum of all odd numbers
         sum1 := sum1 + num;
        --next odd number
        num := num + 2;
    -- end  loop
    END LOOP;
dbms_output.Put_line('Sum of all odd numbers is '|| sum1);
END;
/


-- Display all even number from 1 to n
DECLARE
    -- Declare variable num
    num NUMBER(3) := &start_even;
    sum1 NUMBER(4) := 0;
BEGIN
    WHILE num <= &end_even LOOP
        -- Display even number
        dbms_output.Put_line(num);
        -- Sum of even numbers
        sum1 := sum1 + num;
        -- Next even number
        num := num + 2;
    -- End  loop
    END LOOP;
    -- Display even number
        dbms_output.Put_line('Sum of even numbers is ' || sum1);
END;
/



DECLARE

    -- Declare variable n, s, r, len

    -- and m of datatype number

    n NUMBER := &print_num;

    r NUMBER;

BEGIN

    -- Calculating modulo

    r := MOD(n, 2);

    IF r = 0 THEN

      dbms_output.Put_line('This is an '||'Even'||' Number');

    ELSE

      dbms_output.Put_line('This is an '||'Odd'||' Number');

    END IF;

END;

--End program 

/



 CREATE TYPE number_row_type AS OBJECT 

(
  num NUMBER
);

CREATE TYPE number_set_type AS TABLE OF number_row_type;

CREATE OR REPLACE FUNCTION number_range(p_start IN PLS_INTEGER, p_end IN PLS_INTEGER)
    RETURN number_set_type
    PIPELINED
IS
    out_rec number_row_type := number_row_type(NULL);

BEGIN
  FOR i IN p_start .. p_end LOOP
    out_rec.num := i;
    pipe row(out_rec);
  END LOOP;

END number_range;
/


No comments:

Post a Comment

How to install and configure Oracle Apex 24.1 with ORDS 22, Tomcat 9 and Jasper Report 7 on Oracle Linux 8.10

#########################Install Oracle  APEX 24.1################################ ----------------------------------------------------...