PL/SQL常用語法及舉例


PLSQL語句

DECLARE 聲明部分

BEGIN 程序編寫,SQL語句

EXECPTION 處理異常

END;

/

聲明部分(DECLARE)

SQL> set serveroutput on --打開輸出

SQL> declare

  2  v_num number;

  3  begin

  4  v_num:=30;

  5  dbms_output.put_line('V_NUM'||v_num);

  6  end;

  7  /

V_NUM30

查找empno為7900的員工的名字

declare

v1 scott.emp.ename%type;

v2 scott.emp.sal%type;

begin

select ename,sal into v1,v2 from scott.emp where empno=7900;

dbms_output.put_line('ename:'||v1);

dbms_output.put_line('sal:'||v2);

end;

/

set serveroutput on

/

查找雇員號和姓名

set serveroutput on

declare

   v_eno number;

   v_ename varchar2(10);

   begin

   v_eno:=&empno;

   select ename into v_ename from emp where empno=v_eno;

   dbms_output.put_line('number:'||v_eno||'name:'||v_ename);

   end;

   /

求平均工資

SQL> !vi test.sql

SQL> !cat test.sql

declare

v_avgsal number(6,2);

begin

select avg(sal) into v_avgsal from scott.emp where deptno=&no;

dbms_output.put_line('avg_sal:'||v_avgsal);

end;

SQL> @test.sql

  7  /

Enter value for no: 20

old   4: select avg(sal) into v_avgsal from scott.emp where deptno=&no;

new   4: select avg(sal) into v_avgsal from scott.emp where deptno=20;

PL/SQL procedure successfully completed.

聲明變量的語法

組成:

CONSTANT:定義常量

NOT NULL:表示此變量不允許設置為NULL

:=value:表示在變量聲明時,設置好其初始化內容

DECLARE

V_resultA CONSTANT NUMBER NOT NULL:=100;

BEGIN

DBMS_OUTPUT.put_line('v_resultA常量內容:'||(v_resultA));

END;

/

使用%TYPE聲明變量類型(對列類型賦值)

DECLARE

eno emp.emono%TYPE;

ename emp.ename%TYPE;

BEGIN

  DBMS_OUTPUT.put_line(請輸入雇員編號:);

  dbms_output.put_line('sal:'||v2);

end;

使用%ROWTYPE標記可以定義表中一行記錄的類型(對行類型賦值)

SQL> DECLARE

  2  deptRow dept%ROWTYPE;

  3  BEGIN

  4  SELECT * INTO deptRow FROM dept WHERE deptno=10;

  5  DBMS_OUTPUT.put_line('deptno:'||deptRow.deptno||',name:'||deptRow.dname||',loc:'||deptRow.loc);

  6  end;

  7  /

使用關系運算符

DECLARE

        v_url VARCHAR2(50):='www.vdedu.com.cn';

        v_num1 NUMBER:=80;

        v_num2 NUMBER:=30;

BEGIN

        IF v_num1>v_num2 THEN

                DBMS_OUTPUT.put_line('A');

        END IF;

        IF v_url LIKE '%vdedu%' THEN

                DBMS_OUTPUT.put_line('includes vdedu');

        END IF;

END;

 

 

AND   OR   NOT運算符

 

DECLARE

v_flag1 BOOLEAN:=TRUE;

v_flag2 BOOLEAN:=FALSE;

v_flag3 BOOLEAN;

BEGIN

IF v_flag1 and (NOT v_flag2) THEN

DBMS_OUTPUT.PUT_LINE('1');

END IF;

IF v_flag1 or v_flag3 THEN

DBMS_OUTPUT.PUT_LINE('2');

END IF;

IF v_flag1 and v_flag3 is null THEN

DBMS_OUTPUT.PUT_LINE('3');

END IF;

END;

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM