procedure:存储过程
eg:
 
create or replace procedure p   --这儿是和plsql的区别
        is
        cursor c
        is 
            select * from emp2 for  update;
        --v_temp c%rowtype;
 
begin
 
        for v_temp in c 
            loop 
                    if(v_temp.sal< 2000) then
                        update emp2 set sal=sal*2 where current of c ;
                    elsif(v_temp.sal = 5000) then
                        delete from emp2  where current of c;
                    end if;
            end loop;
            commit;
end;
 
执行过程的命令:exec p;    begin p end;
 
带参数的存储过程;
create or replace procedure p   --in表示传入参数 out传出参数,
        (v_a in number,v_b number ,v_ret out number,v_temp in out number)
is
 
begin 
        if(v_a > v_b) then
                v_ret := v_a;
        else
            v_ret := v_b;
        end if;
    v_temp := v_temp+1;
end;
 
调用过程:
declare 
        v_a number := 3;
        v_b number := 4;
        v_ret number ;
        v_temp number := 5;
 
begin
            p(v_a,v_b,v_ret,v_temp);
            dbms_output.put_line(v_ret);
            dbms_output.put_line(v_temp);
end;
 
函数:function
 
create or replace  function sal_tax
        (v_sal number)   --声明了一个函数
        return number
is 
begin
        if(v_sal < 2000) then
                return 0.10;
        elsif(v_sal < 2750) then
                return 0.15;
        else
                return 0.20;
        end if;
end;
 
函数的调用::select lower(ename),sal_tax(sal) from emp;
 
触发器:trigger 
不能直接执行,依赖于表
create table emp2_log
(
    uname varchar2(20),
    action varchar2(10),
    atime date
);
 
创建触发器
 
create or replace trigger trig
        after insert or delete or update on emp2 for each row
begin
        if inserting then
            insert into emp2_log values (USER,'insert',sysdate);
        elsif updating then
            insert into emp2_log values(USER,'update',sysdate);
        elsif   deleting then
            insert into emp2_log values (USER,'delete',sysdate);
        end if;
end;
 
update emp2 set sal=sal*2 where deptno = 30;
 
drop triggle trig;(删除)
 
create  or replace trigger    trig
        after update on dept
        for each row 
begin 
        update emp set deptno =:NEW.deptno where deptno = :OLD.deptno;
end;
 
update dept set deptno = 99 where deptno = 10;
 
树状结构的存储于显示:
 
create table ariticle
(
            id number primary key,
            cont varchar2(4000),
            pid number,
            isleaf number(1), -- 0代表非叶子节点,1代表叶子节点
            alevel number(2)
);
 
insert into ariticle values(1,'ahshdhshd',0,0,0);
insert into ariticle values(2,'bhshdhshd',1,0,1);
insert into ariticle values(3,'chshdhshd',2,1,2);
insert into ariticle values(4,dhshdhshd',2,0,2);
insert into ariticle values(5,'ehshdhshd',4,1,3);
insert into ariticle values(6,'fhshdhshd',10,1);
insert into ariticle values(7,'ghshdhshd',6,1,0);
insert into ariticle values(8,'hhshdhshd',3,0,4);

insert into ariticle values(9,'ihshdhshd',7,0,0);
insert into ariticle values(10,'jhshdhshd',9,0,3);
 
commit;(提交)
 
 
 
create or replace procudure p (v_pid ariticle.pid%type,v_level binary_integer)
is cursor c 
    is select * from ariticle where pid = v__pid;
    v_preStr varchar2(1024) :='';
begin 
    for i in 0..v_level loop
        v_preStr :=v_preStr || '       ';
        for v_ariticle in c 
        loop
        dbms_output.put_line(v_preStr || v_ariticle.cont);
           if (v_ariticle.isleaf = 0) then
                p(v_ariticle.id,v_level+1);
            end if;
        end loop;
end;
 
exec p(0);
 
转载至:http://blog.csdn.net/zhaoming262350/article/details/8929878?utm_source=tuicool
转载至:http://blog.csdn.net/zhaoming262350/article/details/8929878?utm_source=tuicool
转载至:http://blog.csdn.net/zhaoming262350/article/details/8929878?utm_source=tuicool

plsql中的procedure和function编程的更多相关文章

  1. Cursor、Exception、Procedure、Function、Package、Trigger(day06)

    回顾: 1.record类型 定义record类型,声明变量,保存s_dept表中id = 31部门信息 declare /* 定义record类型 */ type deptrecord is rec ...

  2. Delphi 中的 procedure of object

    转载:http://www.cnblogs.com/ywangzi/archive/2012/08/28/2659811.html 总结:TMyEvent = procedure of object; ...

  3. 在PLSQL中编译复杂的java(转)

    原文地址:在PLSQL中编译复杂的java PLSQL中可以编译运行JAVA程序. 一个简单的例子: create or replace and compile java source named x ...

  4. Delphi 中的 procedure of object (类方法存在一个隐藏参数self),简单深刻 good

    其实要了解这些东西,适当的学些反汇编,WINDOWS内存管理机制,PE结构,看下李维的VCL架构剖析可以很好理解type TMyEvent = procedure of object;这是一种数据类型 ...

  5. [独孤九剑]Oracle知识点梳理(六)数据库常用对象之Procedure、function、Sequence

    本系列链接导航: [独孤九剑]Oracle知识点梳理(一)表空间.用户 [独孤九剑]Oracle知识点梳理(二)数据库的连接 [独孤九剑]Oracle知识点梳理(三)导入.导出 [独孤九剑]Oracl ...

  6. --1.plsql中学习job

    --1.plsql中学习job --学习job --建表 create table test_job(para_date date); commit; insert into test_job val ...

  7. plsql中学习job

    --1.plsql中学习job --学习job --建表 create table test_job(para_date date); commit; insert into test_job val ...

  8. 关于PLSQL中的一些问题总结:在PLSQL中书写DDL等

    关于问题前导,使用的数据表中涉及到的字段和类型: 在PLSQL中create.drop.truncate等DDL是没有办法直接执行的. 必须要使用: Execute immediate 'DDL语句' ...

  9. Difference between Stored Procedure and Function in SQL Server

    Stored Procedures are pre-compile objects which are compiled for first time and its compiled format ...

随机推荐

  1. BZOJ1386 : [Baltic2000]Stickers

    显然每一位的限制独立,对于每一位求出仅限制该位下的最大数,然后求最小值即可. 假设当前要求数字$d$的答案: 考虑填数字的过程,可以看作依次考虑一个序列中的每个数,当前缀和$<0$时退出. 设$ ...

  2. js合并table指定列

    function MergeTableCell(tableId, startRow, endRow, col) { var tb = document.getElementById(tableId); ...

  3. Analysis CDI

    CDI是一组服务,它们一起使用,使开发人员可以轻松地在Web应用程序中使用企业bean和JavaServer Faces技术.CDI设计用于有状态对象,还有许多更广泛的用途,允许开发人员以松散耦合但类 ...

  4. centos 踩坑集锦

    定时任务 top 命令添加定时任务无效 我通过以下命令获取总进程数与僵尸进程数 vim procs.sh procs_total=`/bin/top -n 1|grep Tasks|sed 's/,/ ...

  5. B4 and After: Managing Hierarchy, Partitioning, and Asymmetry for Availability and Scale in Google’s Sofware-Defined WAN

    B4及之后:为谷歌软件定义WAN的可用性和扩展管理层次化.划分和不对称 本文为SIGCOMM 2018会议论文,由谷歌提供. 笔者翻译了该论文.由于时间仓促,且笔者英文能力有限,错误之处在所难免:欢迎 ...

  6. SQLite异常 qAdmin: Cannot perform this operation on a closed dataset.【申明:来源于网络】

    SQLite异常 qAdmin: Cannot perform this operation on a closed dataset. 当使用 SQLite administrator,打开SQLit ...

  7. Spring AOP实现 Bean字段合法性校验

    使用SpringAop 验证方法参数是否合法   先定义两个注解类ValidateGroup 和 ValidateFiled ValidateGroup .java package com.zf.an ...

  8. [Swift]LeetCode945. 使数组唯一的最小增量 | Minimum Increment to Make Array Unique

    Given an array of integers A, a move consists of choosing any A[i], and incrementing it by 1. Return ...

  9. Android开发:Android虚拟机启动错误Can't find 'Linux version ' string in kernel image file

    Android启动出错,虚拟机报错信息如下: Starting emulator for AVD 'test' emulator: ERROR: Can't find 'Linux version ' ...

  10. 一张图看懂STM32芯片型号的命名规则

    意法半导体已经推出STM32基本型系列.增强型系列.USB基本型系列.增强型系列:新系列产品沿用增强型系列的72MHz处理频率.内存包括64KB到256KB闪存和 20KB到64KB嵌入式SRAM.新 ...